From 98fa53357a66f474090304e53959be5d433d5e5f Mon Sep 17 00:00:00 2001 From: Claes Redestad Date: Tue, 31 Aug 2021 11:32:33 +0000 Subject: [PATCH] 8273100: Improve AbstractStringBuilder.append(String) when using CompactStrings Reviewed-by: rriggs, alanb --- .../java/lang/AbstractStringBuilder.java | 21 +++++++++++++------ 1 file changed, 15 insertions(+), 6 deletions(-) diff --git a/src/java.base/share/classes/java/lang/AbstractStringBuilder.java b/src/java.base/share/classes/java/lang/AbstractStringBuilder.java index ff075f144ca..a2adf07d8a2 100644 --- a/src/java.base/share/classes/java/lang/AbstractStringBuilder.java +++ b/src/java.base/share/classes/java/lang/AbstractStringBuilder.java @@ -603,9 +603,7 @@ abstract class AbstractStringBuilder implements Appendable, CharSequence { } int len = asb.length(); ensureCapacityInternal(count + len); - if (getCoder() != asb.getCoder()) { - inflate(); - } + inflateIfNeededFor(asb); asb.getBytes(value, count, coder); count += len; return this; @@ -1712,15 +1710,26 @@ abstract class AbstractStringBuilder implements Appendable, CharSequence { } } - private void putStringAt(int index, String str, int off, int end) { - if (getCoder() != str.coder()) { + private void inflateIfNeededFor(String input) { + if (COMPACT_STRINGS && (coder != input.coder())) { inflate(); } + } + + private void inflateIfNeededFor(AbstractStringBuilder input) { + if (COMPACT_STRINGS && (coder != input.getCoder())) { + inflate(); + } + } + + private void putStringAt(int index, String str, int off, int end) { + inflateIfNeededFor(str); str.getBytes(value, off, index, coder, end - off); } private void putStringAt(int index, String str) { - putStringAt(index, str, 0, str.length()); + inflateIfNeededFor(str); + str.getBytes(value, index, coder); } private final void appendChars(char[] s, int off, int end) {