Java 字符串類主要有String、StringBuffer、StringBuilder、StringTokenizer
1.字符串類型底層都是使用char數組進行實現.
2.從jdk1.7以后,StringBuffer和StringBuilder均繼承自AbstractStringBuilder。
提供的方法基本相似,StringBuffer不提供線程同步,StringBuilder是線程同步的,故StringBuilder效率不如StringBuffer
3.對字符串進行操作時,由於String、StringBuffer、StringBuilder都是由char數組實現的,
類似append的操作都會重新產生一個新char數組,只不過由於StringBuffer和StringBuilder的char數組並不是final的,
所以表現為沒有產生新的StringBxxxxx對象,但是內部的char數組value的指向是發生了變化的。
4.對字符串進行操作時,由於String的char數組是final的所以任何對String的操作都會產生一個新的對象,StringBuffer和
StringBuilder可以反推。
5.String字符串連接時底層實現方式
例如:
String s1 = "s1";
String s2 = "s2";
String s3 = s1 + s2
對連接部分進行反編譯后得到如下代碼
6: new #4 // class java/lang/StringBuilder 9: dup 10: invokespecial #5 // Method java/lang/StringBuilder."<init>":()V 13: aload_1 14: invokevirtual #6 // Method java/lang/StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder; 17: aload_2 18: invokevirtual #6 // Method java/lang/StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder; 21: invokevirtual #7 // Method java/lang/StringBuilder.toString:()Ljava/lang/String; 24: astore_3
可見是采用StringBuilder進行實現的。
6.至於StringTokenizer不需要了解,Api中說明“出於兼容性的原因而被保留的遺留類”,估計是某個核心類用到才被保留的【個人YY】
