这是一个关于惯例的问题。以下两组命令返回相同的结果。
a = [1, 2, 3]
a.first # => 1
a[0] # => 1
a.last # => 3
a[-1] # => 3
在Ruby,显式索引或函数中哪些是首选的?当然,假设这是在代码中 总是 访问第一个或最后一个元素。
注意:我一直在考虑每个周期都会采取的周期。因为 first
和 last
接受参数,他们会有更多的开销,但我不知道这是否会影响社区的偏好。
谢谢!
编辑
如果你看过这篇文章的评论,我的最后一段就有一个很大的争论。虽然我没记住这一点 [x]
相当于 .[](x)
我的结论是正确的,第一个和最后一个有更多的开销。考虑到两者的性质,我认为这是由于参数检查 first
/last
。这些需要检查是否存在参数 []
可以假设它们存在。
码
require 'benchmark'
a = [1..1000]
MAX = 1000000
Benchmark.bm(15) do |b|
b.report("small first") { MAX.times do; a.first; end }
b.report("small [0]") { MAX.times do; a[0]; end }
b.report("small last") { MAX.times do; a.last; end }
b.report("small [-1]") { MAX.times do; a[-1]; end }
end
a = [1..100000000000]
Benchmark.bm(15) do |b|
b.report("large first") { MAX.times do; a.first; end }
b.report("large [0]") { MAX.times do; a[0]; end }
b.report("large last") { MAX.times do; a.last; end }
b.report("large [-1]") { MAX.times do; a[-1]; end }
end
结果
user system total real
small first 0.350000 0.000000 0.350000 ( 0.901497)
small [0] 0.330000 0.010000 0.340000 ( 0.857786)
small last 0.370000 0.000000 0.370000 ( 1.054216)
small [-1] 0.370000 0.000000 0.370000 ( 1.137655)
user system total real
large first 0.340000 0.010000 0.350000 ( 0.897581)
large [0] 0.320000 0.010000 0.330000 ( 0.889725)
large last 0.350000 0.000000 0.350000 ( 1.071135)
large [-1] 0.380000 0.000000 0.380000 ( 1.119587)