In Java, it's a common best practice to do string concatenation with StringBuilder due to the poor performance of appending strings using the + operator. Is the same practice recommended for Scala or has the language improved on how java performs its string concatenation?
4 Answers
Scala uses Java strings (java.lang.String), so its string concatenation is the same as Java's: the same thing is taking place in both. (The runtime is the same, after all.) There is a special StringBuilder class in Scala, that "provides an API compatible with java.lang.StringBuilder"; see http://www.scala-lang.org/api/2.7.5/scala/StringBuilder.html.
But in terms of "best practices", I think most people would generally consider it better to write simple, clear code than maximally efficient code, except when there's an actual performance problem or a good reason to expect one. The + operator doesn't really have "poor performance", it's just that s += "foo" is equivalent to s = s + "foo" (i.e. it creates a new String object), which means that, if you're doing a lot of concatenations to (what looks like) "a single string", you can avoid creating unnecessary objects — and repeatedly recopying earlier portions from one string to another — by using a StringBuilder instead of a String. Usually the difference is not important. (Of course, "simple, clear code" is slightly contradictory: using += is simpler, using StringBuilder is clearer. But still, the decision should usually be based on code-writing considerations rather than minor performance considerations.)
 
    
    - 175,680
- 26
- 273
- 307
- 
                    1In my case I'm very concerned about performance hence why I'm asking the question. Thanks for all the info! – bionicseraph Dec 22 '11 at 19:40
- 
                    AFAIK, the JVM automatically treats repeated '+' concatenations in an expression the same way as it would do a stringbuffer. So there's no performance difference really. – aishwarya Dec 22 '11 at 19:48
- 
                    @aishwarya: The JLS recommends that compilers optimize `foo + bar + baz + bip` to the equivalent of `new StringBuilder(foo).append(bar).append(baz).append(bip).toString()` and `"foo" + "bar" + "baz" + "bip"` to `"foobarbazbip"`, but those are pretty narrow cases. And I don't think JVMs (as opposed to compilers) generally do any sort of optimization along those lines, though I could be wrong. – ruakh Dec 22 '11 at 20:08
- 
                    12pet peeve: using + in a loop results in O(n^2) complexity, while using a StringBuilder in O(n). The extra objects are a minor problem; the explosion in complexity is a major one. – Philip Potter Sep 12 '12 at 06:58
- 
                    @PhilipPotter: Good point. I've edited my answer to mention that `StringBuilder` also helps avoid "repeatedly recopying earlier portions from one string to another". – ruakh Sep 12 '12 at 13:27
Scalas String concatenation works the same way as Javas does.
val x = 5
"a"+"b"+x+"c"
is translated to
new StringBuilder()).append("ab").append(BoxesRunTime.boxToInteger(x)).append("c").toString()
StringBuilder is scala.collection.mutable.StringBuilder. That's the reason why the value appended to the StringBuilder is boxed by the compiler.
You can check the behavior by decompile the bytecode with javap.
 
    
    - 52,967
- 18
- 114
- 136
I want to add: if you have a sequence of strings, then there is already a method to create a new string out of them (all items, concatenated). It's called mkString.
Example: (http://ideone.com/QJhkAG)
val example = Seq("11111", "2222", "333", "444444")
val result = example.mkString
println(result) // prints "111112222333444444"
 
    
    - 8,022
- 3
- 31
- 66
Scala uses java.lang.String as the type for strings, so it is subject to the same characteristics.
 
    
    - 295,120
- 86
- 501
- 681
