loop { break }
可以正常工作,但
block = Proc.new { break }
# or
# block = lambda { break }
loop(&block) # => LocalJumpError: break from proc-closure
break
可以block variable
吗?
更新
更多解释的例子:
def odd_loop
i = 1
loop do
yield i
i += 2
end
end
def even_loop
i = 2
loop do
yield i
i += 2
end
end
# This work
odd_loop do |i|
puts i
break if i > 10
end
# This doesn't work
break_greater_10 = Proc.new do |i|
puts i
break if i > 10
end
odd_loop(&break_greater_10) # break from proc-closure (LocalJumpError)
even_loop(&break_greater_10) # break from proc-closure (LocalJumpError)
根据我的理解,Proc.new
应该与块相同(它可以return
来自块的函数),但我不明白为什么不能打破循环。
P.S。抱歉我的英文不好>〜<
答案 0 :(得分:6)
要解决这个问题,你可以
raise StopIteration
这对我有用。
答案 1 :(得分:2)
要从块中返回,您可以使用next
关键字。
def foo
f = Proc.new {next ; p 1}
f.call
return 'hello'
end
puts foo # => 'hello' , without 1