本文共 1183 字,大约阅读时间需要 3 分钟。
在编译期被确定,并被保存在已编译的.class文件中的一些数据:
它包括了关于类、方法、接口等中的常量,也包括字符串常量
**********************************************************************
用new String()创建的字符串不是常量,不能在编译期就确定
所以new String()创建的字符串不放入常量池中,它们有自己的地址空间
再补充介绍一点:
存在于.class文件中的常量池,在运行期被JVM装载,并且可以扩充。
String的 intern() 方法就是扩充常量池的一个 方法:
当一个String实例str调用 intern() 方法时,Java查找常量池中是否有相同Unicode的字符串常量,
如果有,则返回其的引用, 如果没有,则在常量池中增加一个Unicode等于str的字符串并返回它的引用;
public static void main(String[] args) { /* Java会确保一个字符串常量只有一个拷贝 */ String s1 = "hello"; String s2 = "hello"; // s2 == s1 String s3 = "he" + "llo"; // s3 == s1 == s2 String s6 = s2 + s3 ; // s6 != s1 编译时没计算出来 String s4 = new String("hello"); // s4 != s1 String s5 = new String(s4); // s5 != s4 // s4.intern()返回的是常量池中"hello"的引用 System.out.println( s4.intern() == s1 ); }true
StringBuffer s0=new StringBuffer("hello"); StringBuffer s1=new StringBuffer("hello"); System.out.println( s0 == sb1 ); System.out.println( s0.equals(s1) ); System.out.println( s0.toString().equals( s1.toString() ) );falsefalse true
StringBuffer 类没有重写Object类下的equals方法,
所以实质还是==比较,所以如果需要比较两个StringBuffer对象是否相等则toString()方法转为String。
转载地址:http://vzgxi.baihongyu.com/