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