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