Proc是对块及其context(局部变量的作用域以及栈框架)进行对象化处理之后得到的过程对象。您可以像使用无名函数那样来使用Proc,但它不会导入局部变量的作用域(可以把动态局部变量用作Proc局部变量)。
在下例中,正因为Proc一直保持着局部变量的作用域,所以才能调用var变量。
var = 1 $foo = Proc.new { var } var = 2 def foo $foo.call end p foo # => 2
从生成Proc的方法中返回以后,若Proc中出现return或retry的话,会引发LocalJumpError异常。
def foo proc { return } end foo.call # => in `call': return from proc-closure (LocalJumpError) def foo proc { retry } end foo.call # => in `call': retry from proc-closure (LocalJumpError)
若在Proc前面加上"&"并将其传给一个带块的方法时,其运作情形类似于调用块。但从严格意义上讲,其间还存在以下不同。
# 没问题 (1..5).each { break } # 在ruby 1.6.7, 1.8中没问题。在1.6.8中则发生异常 proc = Proc.new { break } (1..5).each(&proc) # 在ruby 1.6 中是 LocalJumpError # 在ruby 1.8 中,再次运行each proc = Proc.new { retry } (1..5).each(&proc) #=> retry from proc-closure (LocalJumpError)
这正是Proc对象用作调用块时的限制。
Proc.new Proc.new { ... }
对块及其context进行对象化处理之后返回结果。
若没有给出块的话,就会把调用该方法的方法所带的块转换为Proc对象并将其返回。
def foo pr = Proc.new pr.call(1,2,3) end foo {|args| p args } # => [1, 2, 3]
Proc.new方法深入
Proc.new对块及其context进行对象化处理之后返回结果。
若没有给出块的话,就会把调用该方法的方法所带的块转换为Proc对象并将其返回。
def foo pr = Proc.new pr.call(1,2,3) end foo {|args| p args } # => [1, 2, 3] 这与下例相同 def foo yield(1,2,3) end foo {|args| p args } # => [1, 2, 3]
若主调方法并没有带块时,则引发ArgumentError异常。
def foo Proc.new end foo # => -:2:in `new': tried to create Proc object without a block (ArgumentError) from -:2:in `foo' from -:4
在使用Proc.new时,若定义了Proc#initialize方法的话,就在对象初始化时调用该方法。除此以外,它和proc是相同的。
利用 Proc.new 方法,或者对 proc 方法指定块,都可以创建代表块的 Proc 对象。
通过调用 Proc#call 方法执行块。调用 Proc#call 方法时的参数会作为块变量,块中最后一个表达式的值则为 Proc#call 的返回值。Proc#call 还有一个名称叫 Proc#[]。
# 判断西历的年是否为闰年的处理 leap = Proc.new do |year| year % 4 == 0 && year % 100 != 0 || year % 400 ==0 end p leap.call(2000) #=> true p leap[2013] #=> false p leap[2016] #=> true
将块变量设置为 |* 数组 | 的形式后,就可以像方法参数一样,以数组的形式接收可变数量的参数。
double = Proc.new do |*args| args.map{|i| i * 2 } # 所有元素乘两倍 end p double.call(1, 2, 3) #=> [2, 3, 4] p double[2, 3, 4] #=> [4, 6, 8]
除此以外,定义普通方法时可使用的参数形式,如默认参数、关键字参数等,几乎都可以被用于块变量的定义,并被指定给 Proc#call 方法。
本文向大家介绍详解Ruby中的代码块对象Proc,包括了详解Ruby中的代码块对象Proc的使用技巧和注意事项,需要的朋友参考一下 Proc对象 Proc是由块转换来的对象。创建一个Proc共有四种方法,分别是: 示例代码 除了上面的四种之外,还有一种通过&操作符的方式,将代码块与Proc对象进行转换。如果需要将某个代码块作为参数传递给方法,需要通过为这个参数添加&符号,并且其位置必须是在参数的最
本文向大家介绍Ruby中的block、proc、lambda区别总结,包括了Ruby中的block、proc、lambda区别总结的使用技巧和注意事项,需要的朋友参考一下 在规则引擎中,Ruby 的闭包使用特别频繁,而且有 block,Proc和 lambda 等后几种形式的用法,很让人困惑。为了深入理解代码,再次认真学习了一下 Ruby 的闭包,特别是 block,proc 和 lambda 几
本文向大家介绍Ruby中使用Block、Proc、lambda实现闭包,包括了Ruby中使用Block、Proc、lambda实现闭包的使用技巧和注意事项,需要的朋友参考一下 闭包(Closure),是指未绑定到任何对象的自由代码,闭包中的代码与任何对象和全局变量无关,只与执行此段代码的上下文相关。 今天我们简要的看一下ruby中的闭包实现。 Ruby中的闭包实现有:Block,Proc,Lamb
provides a mechanism to support standalone processes you can find the sample at https://www.wenjiangs.com/doc/BZ7EWB2Eexamples/ngx_proc_daytime_module Examples processes { process echo { e
我是Ruby的新手,正在尝试我在Ruby中的前几个程序来理解这些概念。现在,在类方法概念中,在尝试基础知识时,我遇到了以下问题。 我有一个类方法“Servers.valid_requestor”。 这应该检查提供的用户名是否有效,它基于我正在使用的预定义用户名,如果是,它应该在main中执行某些代码。 现在这里的问题是,每当我尝试使用myI获取用户名nput.user_name它返回my_inpu
问题内容: 1)是否可以访问未在/ proc / iomem中定义的物理地址? 2)如果设备的物理地址范围未出现在/ proc / iomem中,是否表示该设备尚未被使用/初始化? 问题答案: 1)是否可以访问未在/ proc / iomem中定义的物理地址? 是。 假设内存映射所有直接连接的外围设备的ARM处理器,驱动程序可以执行将物理内存映射到虚拟内存以进行访问的操作。 但是正确编写的驱动程序