aboutsummaryrefslogtreecommitdiff
path: root/libjava/java/lang
diff options
context:
space:
mode:
authorTom Tromey <tromey@redhat.com>2005-06-01 15:52:45 +0000
committerTom Tromey <tromey@gcc.gnu.org>2005-06-01 15:52:45 +0000
commit68d8b93454c20a663d4b259919d487fe16519837 (patch)
treed45776264c7ddfe40e12a61a6bd2555f42877538 /libjava/java/lang
parent75fe7b2f406d638fa6de89c44e0a862ab04a0b5e (diff)
downloadgcc-68d8b93454c20a663d4b259919d487fe16519837.zip
gcc-68d8b93454c20a663d4b259919d487fe16519837.tar.gz
gcc-68d8b93454c20a663d4b259919d487fe16519837.tar.bz2
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
Diffstat (limited to 'libjava/java/lang')
-rw-r--r--libjava/java/lang/natString.cc5
1 files changed, 4 insertions, 1 deletions
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;