1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32
|
require 'benchmark'
TIMES = (ARGV[0] || 1).to_i
TIMES.times do
Benchmark.bm(30) do |bm|
bm.report("control, 10m times") do
ell = nil
10_000_000.times { ell }
end
bm.report("10m lambda.call no args") do
ell = lambda {self}
10_000_000.times { ell.call }
end
bm.report("10m lambda.call one arg") do
ell = lambda {|a| self}
10_000_000.times { ell.call(self) }
end
bm.report("10m lambda.call two args") do
ell = lambda {|a,b| self}
10_000_000.times { ell.call(self, self) }
end
bm.report("10m lambda.call three args") do
ell = lambda {|a,b,c| self}
10_000_000.times { ell.call(self, self, self) }
end
bm.report("10m lambda.call four args") do
ell = lambda {|a,b,c,d| self}
10_000_000.times { ell.call(self,self,self,self) }
end
end
end
|