[jdk25u-dev] RFR: 8357289: Break down the String constructor into smaller methods

Shaojin Wen swen at openjdk.org
Fri Nov 28 15:34:16 UTC 2025


Through JVM Option +PrintInlining, we found that String has a constructor codeSize of 852, which is too large. This caused failed to inline.

The following is the output information of PrintInlining:

                @ 9   java.lang.String::<init> (12 bytes)   inline (hot)
!m                 @ 1   java.nio.charset.Charset::defaultCharset (52 bytes)   inline (hot)
!                  @ 8   java.lang.String::<init> (852 bytes)   failed to inline: hot method too big


In Java code, the big method that cannot be inlined is the following constructor


String(Charset charset, byte[] bytes, int offset, int length) {}

The above String constructor is too large; break it down into smaller methods with a codeSize under 325 to allow them to be inlined by the C2.

-------------

Commit messages:
 - 8357289: Break down the String constructor into smaller methods

Changes: https://git.openjdk.org/jdk25u-dev/pull/32/files
  Webrev: https://webrevs.openjdk.org/?repo=jdk25u-dev&pr=32&range=00
  Issue: https://bugs.openjdk.org/browse/JDK-8357289
  Stats: 181 lines in 1 file changed: 62 ins; 79 del; 40 mod
  Patch: https://git.openjdk.org/jdk25u-dev/pull/32.diff
  Fetch: git fetch https://git.openjdk.org/jdk25u-dev.git pull/32/head:pull/32

PR: https://git.openjdk.org/jdk25u-dev/pull/32


More information about the jdk-updates-dev mailing list