File: lambda_vs_block_with_select.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 (117 lines) | stat: -rw-r--r-- 2,759 bytes parent folder | download
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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
require 'memory_profiler'

n = 10_000

def find_with_proc(argument)
  lambda do |lambda_arg|
    lambda_arg == argument
  end
end

def find(argument, lambda_arg)
  lambda_arg == argument
end

puts "#{n} items - ruby #{RUBY_VERSION}"

puts
puts "find_with_proc"

MemoryProfiler.report do
  100.times do
    1.upto(n).select(&find_with_proc(50))
  end
end.pretty_print

puts
puts "find"

MemoryProfiler.report do
  100.times do
    1.upto(n).select { |i| find(50, i) }
  end
end.pretty_print

# $ ruby benchmarks/allocations/2_lambda_ref_find.rb
# 10000 items - ruby 3.2.2
#
# find_with_proc
# Total allocated: 29600 bytes (400 objects)
# Total retained:  0 bytes (0 objects)
#
# allocated memory by gem
# -----------------------------------
#      29600  other
#
# allocated memory by file
# -----------------------------------
#      29600  benchmarks/allocations/2_lambda_ref_find.rb
#
# allocated memory by location
# -----------------------------------
#      21600  benchmarks/allocations/2_lambda_ref_find.rb:22
#       8000  benchmarks/allocations/2_lambda_ref_find.rb:6
#
# allocated memory by class
# -----------------------------------
#      13600  Enumerator
#       8000  Array
#       8000  Proc
#
# allocated objects by gem
# -----------------------------------
#        400  other
#
# allocated objects by file
# -----------------------------------
#        400  benchmarks/allocations/2_lambda_ref_find.rb
#
# allocated objects by location
# -----------------------------------
#        300  benchmarks/allocations/2_lambda_ref_find.rb:22
#        100  benchmarks/allocations/2_lambda_ref_find.rb:6
#
# allocated objects by class
# -----------------------------------
#        200  Array
#        100  Enumerator
#        100  Proc
#
#
# find
# Total allocated: 21600 bytes (300 objects)
# Total retained:  0 bytes (0 objects)
#
# allocated memory by gem
# -----------------------------------
#      21600  other
#
# allocated memory by file
# -----------------------------------
#      21600  benchmarks/allocations/2_lambda_ref_find.rb
#
# allocated memory by location
# -----------------------------------
#      21600  benchmarks/allocations/2_lambda_ref_find.rb:31
#
# allocated memory by class
# -----------------------------------
#      13600  Enumerator
#       8000  Array
#
# allocated objects by gem
# -----------------------------------
#        300  other
#
# allocated objects by file
# -----------------------------------
#        300  benchmarks/allocations/2_lambda_ref_find.rb
#
# allocated objects by location
# -----------------------------------
#        300  benchmarks/allocations/2_lambda_ref_find.rb:31
#
# allocated objects by class
# -----------------------------------
#        200  Array
#        100  Enumerator