首页 > 代码库 > String构造器中originalValue.length>size 发生的情况
String构造器中originalValue.length>size 发生的情况
最近在看Jdk6中String的源码的时候发现String的有个这样的构造方法,源代码内容如下:
?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | public String(String original) { int size = original.count; char [] originalValue = http://www.mamicode.com/original.value; char [] v; if (originalValue.length > size) { int off = original.offset; v = Arrays.copyOfRange(originalValue, off, off+size); } else { v = originalValue; } this .offset = 0 ; this .count = size; this .value = http://www.mamicode.com/v; } |
这时就对originalValue.length > size这个不解啊。故网上搜寻原因。发现在stackoverflow上有人提到这个问题。还有个国内的文章也说了这个问题。
1 http://stackoverflow.com/questions/12907986/how-could-originalvalue-length-size-happen-in-the-string-constructor
2 http://www.kankanews.com/ICkengine/archives/99041.shtml
看了上面的两篇文章的说明,我彻底的明白了。原来是这样啊。来看看jdk6中String的subString方法。
?
1 2 3 4 5 6 7 8 9 10 11 12 13 | public String substring( int beginIndex, int endIndex) { if (beginIndex < 0 ) { throw new StringIndexOutOfBoundsException(beginIndex); } if (endIndex > count) { throw new StringIndexOutOfBoundsException(endIndex); } if (beginIndex > endIndex) { throw new StringIndexOutOfBoundsException(endIndex - beginIndex); } return ((beginIndex == 0 ) && (endIndex == count)) ? this : new String(offset + beginIndex, endIndex - beginIndex, value); } |
?
1 2 3 4 5 6 | // Package private constructor which shares value array for speed. String( int offset, int count, char value[]) { this .value = http://www.mamicode.com/value; this .offset = offset; this .count = count; } |
看看上面的源码,发现使用substring方法后新的String对象的字符数组还是原来对象的字符数组。这样就出现了originalValue.length > size这个问题。如
?
1 2 3 | String s1= "hello world" ; String s2=s1.substring( 6 ); String s3= new String(s2); |
分析上面的代码 s2的属性char[] value任然是原来s1的属性char[] value=http://www.mamicode.com/{‘h‘,‘e‘,‘l‘,‘l‘,‘o‘,‘ "font-size: 18px;">originalValue.length=11>count=5。故我们可知在这样的情况下会出现本文讨论的问题。
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。