1

当你想一直展平一个数组时,数组的最大深度是已知的,在性能方面总是将最大深度作为参数传递给Array#flatten? 例如,在下面做前者比做后者更好吗?

[[:foo], [:bar], [:baz], ...].flatten(1)

[[:foo], [:bar], [:baz], ...].flatten
4

1 回答 1

4

不在 MRI 上,因为无论您是否设置级别,都会检查元素是否为数组。它本质上是这样做的(psuedo-Ruby,如果你想要原始的 C,它从这里开始)

array.each do |value|
  if !value.is_array? || current_depth >= max_depth
    result << value
  else
    current_depth += 1
    recurse ...
  end
end

实际的实现不是显式递归的,也没有is_array?方法,但是嘿,你明白了。

带回家的信息是您的用例将始终满足!value.is_array?条件,并且永远不会使用您传递的参数,因此您不会通过传递它获得任何收益。

于 2013-01-22T23:49:31.550 回答