主页 > 知识库 > 详解Ruby中的代码块对象Proc

详解Ruby中的代码块对象Proc

热门标签:硅谷的囚徒呼叫中心 呼叫中心市场需求 企业做大做强 语音系统 百度AI接口 电话运营中心 客户服务 Win7旗舰版

Proc对象

Proc是由块转换来的对象。创建一个Proc共有四种方法,分别是:

示例代码

# 法一
inc = Proc.new { | x | x + 1}
inc.call(2) #=> 3

# 法二
inc = lambda {| x | x + 1 }
inc.call(2) #=> 3

# 法三
inc = ->(x) { x + 1}
inc.call(2) #=> 3

# 法四
inc = proc {|x| x + 1 }
inc.call(2) #=> 3

除了上面的四种之外,还有一种通过操作符的方式,将代码块与Proc对象进行转换。如果需要将某个代码块作为参数传递给方法,需要通过为这个参数添加符号,并且其位置必须是在参数的最后一个

符号的含义是: 这是一个Proc对象,我想把它当成代码块来使用。去掉符号,将能再次得到一个Proc对象。

示例代码

def my_method(the_proc)
  the_proc
end

p = my_method {|name| “Hello, #{name} !”}
p.class  #=> Proc
p.call(“Bill”)  #=> “Hello,Bill”


def my_method(greeting)
  “#{greeting}, #{yield}!”
end

my_proc = proc { “Bill” }
my_method(“Hello”, my_proc)

一些需要注意的地方

在使用block时,我会忽略proc的存在,我将proc定位为一个幕后的工作者。我经常写类似下面的代码,

 def f(...)
  ...
  yield
  ...
 end

 def f(..., p)
  ...
  p.call
  ...
 end

 def f(..., p)
  instance_eval p
  ...
 end

 def f(..., p)
  ...
  defime_method m, p
  ...
 end

有些新手会写类似下面的一执行就会报错的代码,

 

 def f(..., p)
  instance_eval p
 end

 def f(..., p)
  instance_eval p.call
 end

也有这样写的,

 def f(..., p)
  instance_eval do
   p.call
  end
 end

或者

 def f(...)
  instance_eval do
   yield
  end
 end

我甚至写过类似下面的代码,

 def f(...)
  instance_eval yield
 end

我们经常在该挂block的时候,却把proc对象当参数传给方法了, 或者不明白p就是block可以直接交给方法使用,我曾经也犯过这样的错误就是因为没有把block和proc正确的区分开来, p是block, p是proc,不到万不得已的情况下不要显式地创建proc,每当我对block和proc之间的关系犯糊涂时,我就会念上几句。

您可能感兴趣的文章:
  • 深入理解Ruby中的代码块block特性
  • Ruby中的block代码块学习教程
  • 详解Ruby中的代码块及其参数传递

标签:崇左 山西 长沙 山西 济南 海南 安康 喀什

巨人网络通讯声明:本文标题《详解Ruby中的代码块对象Proc》,本文关键词  ;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 收缩
    • 微信客服
    • 微信二维码
    • 电话咨询

    • 400-1100-266