File: each_value_v_values_each.rb

package info (click to toggle)
ruby-rspec 3.13.0c0e0m0s1-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 6,856 kB
  • sloc: ruby: 70,868; sh: 1,423; makefile: 99
file content (57 lines) | stat: -rw-r--r-- 1,213 bytes parent folder | download | duplicates (6)
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
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
require 'benchmark'

n = 10_000

m = 1.upto(1000).inject({}) { |m, i| m[i] = i; m }

Benchmark.benchmark do |bm|
  puts "#{n} times - ruby #{RUBY_VERSION}"

  puts
  puts "each_value"

  3.times do
    bm.report do
      n.times do
        m.each_value {}
      end
    end
  end

  puts
  puts "values.each"

  3.times do
    bm.report do
      n.times do
        m.values.each {}
      end
    end
  end
end

# $ ruby benchmarks/values_each_v_each_value.rb
#  10000 times - ruby 1.9.3
#
# each_value
#    0.720000   0.000000   0.720000 (  0.720237)
#    0.720000   0.000000   0.720000 (  0.724956)
#    0.730000   0.000000   0.730000 (  0.730352)
#
# values.each
#    0.910000   0.000000   0.910000 (  0.917496)
#    0.910000   0.010000   0.920000 (  0.909319)
#    0.910000   0.000000   0.910000 (  0.911225)

# $ ruby benchmarks/values_each_v_each_value.rb
# 10000 times - ruby 2.0.0
#
# each_value
#    0.730000   0.000000   0.730000 (  0.738443)
#    0.720000   0.000000   0.720000 (  0.720183)
#    0.720000   0.000000   0.720000 (  0.720866)
#
# values.each
#    0.940000   0.000000   0.940000 (  0.942597)
#    0.960000   0.010000   0.970000 (  0.959248)
#    0.960000   0.000000   0.960000 (  0.959099)