У меня есть ориентир:
@BenchmarkMode(Mode.Throughput)
@Fork(1)
@State(Scope.Thread)
@Warmup(iterations = 10, time = 1, timeUnit = TimeUnit.SECONDS, batchSize = 1000)
@Measurement(iterations = 40, time = 1, timeUnit = TimeUnit.SECONDS, batchSize = 1000)
public class StringConcatTest {
    private int aInt;
    @Setup
    public void prepare() {
        aInt = 100;
    }
    @Benchmark
    public String emptyStringInt() {
        return "" + aInt;
    }
    @Benchmark
    public String valueOfInt() {
        return String.valueOf(aInt);
    }
}
И вот результат:
Benchmark                                          Mode  Cnt      Score      Error  Units
StringConcatTest.emptyStringInt                   thrpt   40  66045.741 ± 1306.280  ops/s
StringConcatTest.valueOfInt                       thrpt   40  43947.708 ± 1140.078  ops/s
Это показывает, что объединение пустой строки с целым числом на 30% быстрее, чем вызов String.value(100). Я понимаю, что "+ 100 преобразован в
new StringBuilder().append(100).toString()
Оптимизация и -XX:+OptimizeStringConcat применяется, что делает ее быстрой. Я не понимаю, почему valueOf сам медленнее, чем конкатенация.
Может кто-то объяснить, что именно происходит, и почему "+ 100 быстрее. Какую магию делает OptimizeStringConcat?