1.JVM维护一张[color=darkred][b]常量池的[/b][/color]hash表,这个hash表是对应常量池的,属于栈内存。
2.字面量赋值会自动隐式调用intern(),所以
这个"abc"是在常量池,属于栈内存,所谓栈中数据共享。共享的依据是JVM维护的对应常量池的hash表。
3.==和equal的差异也在这其中,new出来的东东,都在堆内存上。值可以相等,地址可以不相等。
4.以上三点,可以推广到基本数据类型和对应包装类。
5.我为什么写这篇文章:
str1是一个引用,在栈中;str2也被是一个引用,也在栈中;而我先前一知半解的知道intern方法,但是不清楚intern是对应常量池的hash表,所以产生先new出来的对象,后字面量赋值,str2为什么不指向new的东西的疑惑。好绕,其实我想说得就是:
通过new创建的对象的引用通过intern可以指向常量池中的对象。改变的是引用的指向,字符串abc有两个地址,因为分别用了new和字面量。
也就是节省内存一说。
举个例子,读输入流,相同的字符串只存一次输出,这个就可以用intern。
String str2 = new String("abc");
String str1 = "abc";
System.out.println(str2 == str2.intern()); //false
System.out.println(str1 == str2.intern()); //true
System.out.println(str1.intern() == str2); //false
2.字面量赋值会自动隐式调用intern(),所以
String str1 = "abc";
String str2 = "abc";
String str3 = "abc";
System.out.println(str1 == str2); //true
System.out.println(str2 == str3); //true
这个"abc"是在常量池,属于栈内存,所谓栈中数据共享。共享的依据是JVM维护的对应常量池的hash表。
3.==和equal的差异也在这其中,new出来的东东,都在堆内存上。值可以相等,地址可以不相等。
4.以上三点,可以推广到基本数据类型和对应包装类。
5.我为什么写这篇文章:
String str1 = new String("abc");
String str2 = "abc"
str1是一个引用,在栈中;str2也被是一个引用,也在栈中;而我先前一知半解的知道intern方法,但是不清楚intern是对应常量池的hash表,所以产生先new出来的对象,后字面量赋值,str2为什么不指向new的东西的疑惑。好绕,其实我想说得就是:
通过new创建的对象的引用通过intern可以指向常量池中的对象。改变的是引用的指向,字符串abc有两个地址,因为分别用了new和字面量。
也就是节省内存一说。
举个例子,读输入流,相同的字符串只存一次输出,这个就可以用intern。