From c62198bc711e245c169af12b0f63c95e32fa1b69 Mon Sep 17 00:00:00 2001 From: lvl0nax Date: Thu, 2 Nov 2017 12:13:20 +0000 Subject: [PATCH] add substring inclusion checking --- README.md | 27 ++++++++++++++++----------- code/string/===-vs-=~-vs-match.rb | 7 ++++++- 2 files changed, 22 insertions(+), 12 deletions(-) diff --git a/README.md b/README.md index eb924d5..e2e3397 100644 --- a/README.md +++ b/README.md @@ -986,24 +986,29 @@ Comparison: > for a match and not using the resultant match object.
> :warning:
> `Regexp#===` is also faster than `String#match` but you need to switch the order of arguments. +> :warning:
+> `String#include?` This is only useful for cases where you are checking substring inclusion ``` $ ruby -v code/string/===-vs-=~-vs-match.rb.rb -ruby 2.2.2p95 (2015-04-13 revision 50295) [x86_64-darwin14] +ruby 2.4.2p198 (2017-09-14 revision 59899) [x86_64-darwin16] +Warming up -------------------------------------- + String#include? 238.465k i/100ms + String#=~ 161.826k i/100ms + Regexp#=== 147.986k i/100ms + String#match 136.749k i/100ms Calculating ------------------------------------- - String#=~ 98.184k i/100ms - Regexp#=== 92.382k i/100ms - String#match 83.601k i/100ms -------------------------------------------------- - String#=~ 2.442M (± 7.6%) i/s - 12.175M - Regexp#=== 2.259M (± 7.9%) i/s - 11.271M - String#match 1.840M (± 7.3%) i/s - 9.196M + String#include? 5.961M (± 8.5%) i/s - 29.808M in 5.035615s + String#=~ 2.843M (± 8.1%) i/s - 14.241M in 5.040590s + Regexp#=== 2.689M (± 7.3%) i/s - 13.467M in 5.032779s + String#match 2.371M (± 5.2%) i/s - 11.897M in 5.031192s Comparison: - String#=~: 2442335.1 i/s - Regexp#===: 2259277.3 i/s - 1.08x slower - String#match: 1839815.4 i/s - 1.33x slower + String#include?: 5960785.4 i/s + String#=~: 2843384.2 i/s - 2.10x slower + Regexp#===: 2689290.6 i/s - 2.22x slower + String#match: 2370791.0 i/s - 2.51x slower ``` See [#59](https://github.com/JuanitoFatas/fast-ruby/pull/59) and [#62](https://github.com/JuanitoFatas/fast-ruby/pull/62) for discussions. diff --git a/code/string/===-vs-=~-vs-match.rb b/code/string/===-vs-=~-vs-match.rb index 1ebb7bf..fc30a9f 100644 --- a/code/string/===-vs-=~-vs-match.rb +++ b/code/string/===-vs-=~-vs-match.rb @@ -1,6 +1,10 @@ require "benchmark/ips" def fastest + "foo".freeze.include? 'boo' +end + +def faster "foo".freeze =~ /boo/ end @@ -13,7 +17,8 @@ def slow end Benchmark.ips do |x| - x.report("String#=~") { fastest } + x.report("String#include?") { fastest } + x.report("String#=~") { faster } x.report("Regexp#===") { fast } x.report("String#match") { slow } x.compare!