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);
}
文章最後附上一張我們家豆豆的照片^_^