Hello,大家好!我是程序员阿飞!今天是我26岁生日,女友早早就给我发来了祝福信息,还有生日礼物,非常开心!感谢女友陪伴了我这么久,希望我们能够一直走一下。(*^▽^*) 好了,开始今天的学习内容总结:String。
1、字符串的不可变性
一个String对象被创建并赋值后,这个对象的值就不会变。一旦一个String对象在内存中创建,它将是不可改变的,所有的String类中方法并不是改变String对象自己,而是重新创建一个新的String对象。
正因为String对象的不可变性,如果需要对字符串进行大量的修改、添加字符、删除字符等操作尽量不要使用String对象,因为这样会频繁的创建新的对象导致程序的执行效率下降。
2、JDK 6 和 JDK 7 中 subString 的原理及区别
subString(int beginIndex,int endIndex)方法截取字符串并返回【beginindex,endIndex-1】范围的内容。
String i = "abcdef";
j = i.subString(1,3);
System.out.printIn(j);//输出内容:bc
(1)JDK6中的subString
String是通过字符串数组实现的。在dk 6 中,String类包含三个成员变量:char value[], int offset,int count。他们分别用来存储真正的字符数组,数组的第一个位置索引以及字符串中包含的字符个数。
当调用substring方法的时候,会创建一个新的string对象,但是这个string的值仍然指向堆中的同一个字符数组。这两个对象中只有count和offset 的值是不同的。
//JDK 6
String(int offset, int count, char value[]) {
this.value = value;
this.offset = offset;
this.count = count;
}
public String substring(int beginIndex, int endIndex) {
//check boundary
return new String(offset + beginIndex, endIndex - beginIndex, value);
}
JDK 6中的substring导致的问题
如果你有一个很长很长的字符串,但是当你使用substring进行切割的时候你只需要很短的一段。这可能导致性能问题,因为你需要的只是一小段字符序列,但是你却引用了整个字符串(因为这个非常长的字符数组一直在被引用,所以无法被回收,就可能导致内存泄露)。在JDK 6中,一般用以下方式来解决该问题,原理其实就是生成一个新的字符串并引用他。
x = x.substring(x, y) + ""
(2)JDK7中的subString原理
上面提到的问题,在jdk 7中得到解决。在jdk 7 中,substring方法会在堆内存中创建一个新的数组。
//JDK 7
public String(char value[], int offset, int count) {
//check boundary
this.value = Arrays.copyOfRange(value, offset, offset + count);
}
public String substring(int beginIndex, int endIndex) {
//check boundary
int subLen = endIndex - beginIndex;
return new String(value, beginIndex, subLen);
}
文章最后附上一张我们家豆豆的照片^_^
转载于:https://blog.51cto.com/12388374/2357170