ruby 过程对象 解析
程序员文章站
2022-06-24 13:07:30
我们总是希望对未知事件分类.当它发生时,向其它方法传递一块作为参数的代码是最容易地解决方法,也就是说我们希望像处理数据一样处理代码. 一个新的过程对象可以通过proc创建:...
我们总是希望对未知事件分类.当它发生时,向其它方法传递一块作为参数的代码是最容易地解决方法,也就是说我们希望像处理数据一样处理代码.
一个新的过程对象可以通过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
这种简写为你提供了一种方便和可读性更强的写小匿名过程的路子.
一个新的过程对象可以通过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
这种简写为你提供了一种方便和可读性更强的写小匿名过程的路子.