最近看《Effective Java》,其中提到String str = new String("foo");的方式创建String实例的方式不可取。既然有这个构造方法总得有点意义,于是我去看了String的源码:
代码中的if条件让人很疑惑,originalValue.length就是String中char[]的长度,size是当我们用"abc".length() 取到的String长度,什么情况下originalValue.length > size会成立?
其实答案就在于String的split和substring方法,可以参考下面一位朋友的文章[url]http://jarfield.iteye.com/blog/583946[/url]
当我们用String的split方法分割出一个字符串数组时,其实仅仅改变原String中char[]的游标,每个子String都是原来的一个拷贝。即子String的count记录的是子字符串的长度,但是其中的char[]的大小和原字符串是一样的(这也是split会导致内存泄漏的原因)。如果把split出来的字串都用public String(String original)创建一遍即可避免内存泄漏的问题,我想这也是这个看似没用处的构造方法存在的作用。
小弟第一次发文章,才疏学浅,以上纯属个人愚见。
public String(String original) {
int size = original.count;
char[] originalValue = original.value;
char[] v;
if (originalValue.length > size) {
// The array representing the String is bigger than the new
// String itself. Perhaps this constructor is being called
// in order to trim the baggage, so make a copy of the array.
v = new char[size];
System.arraycopy(originalValue, original.offset, v, 0, size);
} else {
// The array representing the String is the same
// size as the String, so no point in making a copy.
v = originalValue;
}
this.offset = 0;
this.count = size;
this.value = v;
}
代码中的if条件让人很疑惑,originalValue.length就是String中char[]的长度,size是当我们用"abc".length() 取到的String长度,什么情况下originalValue.length > size会成立?
其实答案就在于String的split和substring方法,可以参考下面一位朋友的文章[url]http://jarfield.iteye.com/blog/583946[/url]
当我们用String的split方法分割出一个字符串数组时,其实仅仅改变原String中char[]的游标,每个子String都是原来的一个拷贝。即子String的count记录的是子字符串的长度,但是其中的char[]的大小和原字符串是一样的(这也是split会导致内存泄漏的原因)。如果把split出来的字串都用public String(String original)创建一遍即可避免内存泄漏的问题,我想这也是这个看似没用处的构造方法存在的作用。
小弟第一次发文章,才疏学浅,以上纯属个人愚见。