From: marcandre-ruby-core@... Date: 2020-07-13T20:27:50+00:00 Subject: [ruby-core:99157] [Ruby master Bug#17030] Enumerable#grep{_v} should be optimized for Regexp Issue #17030 has been updated by marcandre (Marc-Andre Lafortune). Code to reproduce: ```ruby require 'benchmark-ips' require 'benchmark-memory' arr = %w[foobar foobaz bazquux hello world just making this array longer] REGEXP = /o/ def select_match(arr) arr.select { |e| e.match?(REGEXP) } end def grep(arr) arr.grep(REGEXP) end Benchmark.ips do |x| x.report("select.match?") { select_match(arr) } x.report("grep") { grep(arr) } x.compare! end puts "********* MEMORY *********" Benchmark.memory do |x| x.report("select.match?") { select_match(arr) } x.report("grep") { grep(arr) } x.compare! end ``` ---------------------------------------- Bug #17030: Enumerable#grep{_v} should be optimized for Regexp https://bugs.ruby-lang.org/issues/17030#change-86535 * Author: marcandre (Marc-Andre Lafortune) * Status: Open * Priority: Normal * Backport: 2.5: UNKNOWN, 2.6: UNKNOWN, 2.7: UNKNOWN ---------------------------------------- Currently: ```ruby array.select { |e| e.match?(REGEXP) } # about 3x faster and 6x more memory efficient than array.grep(REGEXP) ``` This is because `grep` calls `Regexp#===` which creates useless `MatchData` -- https://bugs.ruby-lang.org/ Unsubscribe: