You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Hi, the tests in string/concatenation.rb are quite misleading.
The fast method consists of this
def fast
'foo' 'bar'
end
That's not concatenating during calling of fast but on parsing the code. If you write another method just returning foobar, it is as fast as this method.
So I think this is not fair comparison and what you usually want is to concatenate two variables during runtime.
For this use case concat and << are calling the same code, so they have the same performance and both are fine if you want to change the string on the left and not just get two strings concatenated. If you want a new string you can use +.
Some better test could be to compare + and String interpolation
Benchmark.ips do |x|
foo = 'foo'
bar = 'bar'
x.report('String#+') do
foo + bar
end
x.report('String interpolation') do
"#{foo}#{bar}"
end
x.compare!
end
This still has the difference that interpolation can handle nil values, while + cannot.
The text was updated successfully, but these errors were encountered:
@JuanitoFatas I was just running through a project trying to find optimizations, and found something that fit the string concatenation example. I blindly took your results and applied them, basically changing this:
Luckily I am benchmarking everything, so I noticed there's no difference. The reason is fairly obvious of course, as I'm changing the object rather than creating a new object like you are in your examples.
I think this deserves some explanation in the example?
Hi, the tests in
string/concatenation.rb
are quite misleading.The fast method consists of this
That's not concatenating during calling of
fast
but on parsing the code. If you write another method just returningfoobar
, it is as fast as this method.So I think this is not fair comparison and what you usually want is to concatenate two variables during runtime.
For this use case
concat
and<<
are calling the same code, so they have the same performance and both are fine if you want to change the string on the left and not just get two strings concatenated. If you want a new string you can use+
.Some better test could be to compare
+
and String interpolationThis still has the difference that interpolation can handle nil values, while
+
cannot.The text was updated successfully, but these errors were encountered: