我們總是希望對未知事件分類.當它發生時,向其它方法傳遞一塊作為參數的代碼是最容易地解決方案,也就是說我們希望像處理資料一樣處理代碼.
一個新的過程對象可以通過proc建立:
ruby> quux = proc {
| print "QUUXQUUXQUUX!!!\n"
| }
#<Proc:0x4017357c>
現在quux指向一個對象,像其它對象一樣,它也有可以調用的行為.特別的,我們可以用call方法執行它:
ruby> quux.call
QUUXQUUXQUUX!!!
nil
那麼quux可以用做一個方法的參數嗎?當然.
ruby> def run( p )
| print "About to call a procedure...\n"
| p.call
| print "There: finished.\n"
| end
nil
ruby> run quux
About to call a procedure...
QUUXQUUXQUUX!!!
There: finished.
nil
trap方法令到我們可以對任何系統訊號做出我們自己的選擇.
ruby> inthandler = proc{ print "^C was pressed.\n" }
#<Proc:0x401730a4>
ruby> trap "SIGINT", inthandler
#<Proc:0x401735e0>
一般的,敲入^C將導致解譯器退出.但現在一個資訊被列印出來,解譯器繼續執行著,所以你不會丟失掉正在作業的工作.(你不會永遠留在解譯器裡,你仍可以用 exit 或者按 ^D退出)
最後在我們開始下一節之前還應注意的一點是:在將一個過程對象捆綁到一個訊號之前,不是必須給這個過程對象命名的.一個等效的匿名(anonymous)過程對象像這樣
ruby> trap "SIGINT", proc{ print "^C was pressed.\n" }
nil
或著更簡略,
ruby> trap "SIGINT", 'print "^C was pressed.\n"'
nil
這種簡寫為你提供了一種方便和可讀性更強的寫小匿名過程的路子.