a, b, c = 0, 1, 2
[a, b, c].find(&:zero?) # => 0
是否有任何方法可以找到块返回 false 的第一个元素?
[a, b, c].the_method(&:zero?) # => 1
换句话说,它的行为方式与以下相同:
[a, b, c].reject(&:zero?).first
a, b, c = 0, 1, 2
[a, b, c].find(&:zero?) # => 0
是否有任何方法可以找到块返回 false 的第一个元素?
[a, b, c].the_method(&:zero?) # => 1
换句话说,它的行为方式与以下相同:
[a, b, c].reject(&:zero?).first
没有,但你可以用干净的方式创建一个:
a = [0,2,1,0,3]
module Enumerable
def first_not(&block)
find{ |x| !block[x] }
end
end
p a.first_not(&:zero?)
#=> 2
...或非常有趣的黑客方式:
class Proc
def !
proc{ |o,*a| !self[o,*a] }
end
end
p a.find(&!(:zero?.to_proc))
#=> 2
...或简洁但非常危险的方式:
class Symbol
def !
proc{ |o,*a| !o.send(self,*a) }
end
end
p a.find(&!:zero?)
#=> 2
但我主张跳过棘手的Symbol#to_proc
用法并说出你想要的:
p a.find{ |i| !i.zero? }
#=> 2
据我所知,没有标准的方法可以做到这一点(假设 find_all 和 reject 相互引用,但 find 没有引用任何东西)。如果你经常需要它(特别是如果拒绝太慢)你可以自己写
module Enumerable
def first_reject(&block)
find {|a| not (block.call(a)) }
end
end
如果您使用的是 Ruby 2.0,您可能能够避免lazy.reject(&:zero?).first
遍历整个数组的性能损失。