众所周知,谁可以通过 a 将方法传递给迭代器方法&:
prefix.
例如:
["a", "b"].map(&:upcase) #=> ["A", "B"]
def rettwo
2
end
["a", "b"].map(&:rettwo) #=> [2, 2]
问题是,当我编写一个方法时,传递一个方法&:
前缀,我收到一条错误消息:“ArgumentError:没有给出接收者”。
让我展示一下代码:
def a_simple_method &proc
puts proc.class # it shows `Proc`
proc.call
end
def a_iterator_method
puts yield
end
a_simple_method &:rettwo #=> ArgumentError: no receiver given
a_iterator_method &:rettwo #=> ArgumentError: no receiver given
我缺少什么,如何map
就像数组的方法一样处理它
这是有效的。解释如下。
class String
def rettwo
self + self
end
end
def a_simple_method &proc
proc.call('a')
end
def a_iterator_method
yield 'b'
end
a_simple_method(&:rettwo) # => "aa"
a_iterator_method(&:rettwo) # => "bb"
The &:
构造称为Symbol#to_proc
。它将符号变成过程。该过程需要一个接收者作为第一个参数。其余参数用于调用过程。您没有传递任何参数,因此出现“未给出接收者”错误。
以下是附加参数的演示:
class String
def say name
"#{self} #{name}"
end
end
def a_simple_method &proc
proc.call('hello', 'ruby')
end
a_simple_method(&:say) # => "hello ruby"
这是 2008 年的一些博客文章中对 Symbol#to_proc 的定义。现代的 Symbol#to_proc 似乎是用 C 实现的,但这仍然可以帮助理解。
class Symbol
def to_proc
Proc.new { |*args| args.shift.__send__(self, *args) }
end
end
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)