我們總是希望對未知事件分類.當它發生時,向其它方法傳遞一塊作為參數的代碼是最容易地解決方法,也就是說我們希望像處理數據一樣處理代碼.
一個新的過程對象可以通過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
這種簡寫為你提供了一種方便和可讀性更強的寫小匿名過程的路子.