看了一篇有关java内存分配的文章http://developer.51cto.com/art/201009/225071.htm,发现好多让人奇怪的点,比如基本类型的分配竟和c完全不同。
String s = "ab";
String s1 = "a";
String s3 = "a" + "b";//在编译器直接产生新字符串常量在常量区,s == s3
String s2 = s1 + "b";//在运行期执行并在堆上产生新对象,s != s2,(若s1为final则同上)
//底层采用StringBuilder相加 所以比直接用builder慢
String str = new String("a");
str.intern(); //str内容不存在常量区时加入,否则返回该常量区字符串的引用,str.intern() == s1
int arr[] = new int[5]; //java中数组用new来分配内存,所以引用在栈中,数据在堆中
int ia = 1;
int ib = 1;
System.out.println(s2);
System.out.println(System.identityHashCode(ia) + " " + System.identityHashCode(ib));//相同
//返回给定对象的哈希码,该代码与默认的 hashCode()返回的代码一样,无论给定对象的类是否重写 hashCode()。null 引用的哈希码为零。
//默认的 hashCode()是基于对象的地址(引用的值-指向堆地址)产生的
ia = 4;
System.out.println(System.identityHashCode(ia) + " " + System.identityHashCode(ib));//不同
String ss = "a";
String sss = "a";
System.out.println(System.identityHashCode(ss) + " " + System.identityHashCode(sss));//相同
//ia、ib为两个引用,占用空间...