#
# "start in m1 ... "
# "start in m2 ... "
# "start in block in m1 ... "
# "end in m2 ... "
# "end in m1 ... "
只是略过了代码块的最后一行代码,这就是next的工作方式了。我们再来看看break的那个例子如果 用next来写,看看结果是什么?如果你完全理解了上面所写的,相信你已经能在大脑中计算出结果了:
result = [1, 2, 3, 4, 5].map do |i|
next if i > 3
i * 2
end
p result # => [2, 4, 6, nil, nil]
next语句也能带返回值: ``` result = [1, 2, 3, 4, 5].map do |i| next 'next' if i > 3 i * 2 end
p result # => [2, 4, 6, "next", "next"] ```
其他
对于return,在方法中,代码块中都可以使用,而break和next只能在代码块中使用(循环结构中 也可以使用,但是一般它也是用代码块的形式来表示),如果在方法中调用两者会提示语法错误,也就是:
def m1
return # OK
break # Invalid break, compile error (SyntaxError)
next # Invalid next, compile error (SyntaxError)
end
结论
return 大部分情况下和其他语言无异,需要注意在ensure以及Proc和Lambda两种不同的 代码块中的细节问题。
break 在有方法嵌套调用中的代码块中需要注意,它总是返回到调用代码块方法的方法中(有点绕)。
next 最老实,基本不需要注意什么。
最后就是,不只是return能返回值,break和next都能返回值。










