From 68d8b93454c20a663d4b259919d487fe16519837 Mon Sep 17 00:00:00 2001 From: Tom Tromey Date: Wed, 1 Jun 2005 15:52:45 +0000 Subject: re PR libgcj/21753 (String.substring sharing heuristic should be improved) PR libgcj/21753: * java/lang/natString.cc (substring): Changed sharing heuristic. From-SVN: r100454 --- libjava/java/lang/natString.cc | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) (limited to 'libjava/java/lang') diff --git a/libjava/java/lang/natString.cc b/libjava/java/lang/natString.cc index a14f5de..c8f3129 100644 --- a/libjava/java/lang/natString.cc +++ b/libjava/java/lang/natString.cc @@ -833,7 +833,10 @@ java::lang::String::substring (jint beginIndex, jint endIndex) if (beginIndex == 0 && endIndex == count) return this; jint newCount = endIndex - beginIndex; - if (newCount <= 8) // Optimization, mainly for GC. + // For very small strings, just allocate a new one. For other + // substrings, allocate a new one unless the substring is over half + // of the original string. + if (newCount <= 8 || newCount < (count >> 1)) return JvNewString(JvGetStringChars(this) + beginIndex, newCount); jstring s = new String(); s->data = data; -- cgit v1.1