Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

add substring inclusion checking #139

Open
wants to merge 1 commit into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
31 changes: 18 additions & 13 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -985,25 +985,30 @@ Comparison:
> This is only useful for cases where you are checking <br>
> for a match and not using the resultant match object. <br>
> :warning: <br>
> `Regexp#===` is also faster than `String#match` but you need to switch the order of arguments.
> `Regexp#===` is also faster than `String#match` but you need to switch the order of arguments.<br>
> :warning: <br>
> `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 -v code/string/===-vs-=~-vs-match.rb
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.
Expand Down
7 changes: 6 additions & 1 deletion code/string/===-vs-=~-vs-match.rb
Original file line number Diff line number Diff line change
@@ -1,6 +1,10 @@
require "benchmark/ips"

def fastest
"foo".freeze.include? 'boo'
end

def faster
"foo".freeze =~ /boo/
end

Expand All @@ -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!
Expand Down