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