我們總是希望對未知事件分類.當它發生時,向其它方法傳遞一塊作為參數的代碼是最容易地解決方法,也就是說我們希望像處理數據一樣處理代碼.
一個新的過程對象可以通過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