首先看这两行代码:
String s1 = "abc";
String s2 = new String("abc");
之前看到一些学习Java的同僚,对以上两行代码产生疑虑,自己学习到这里,所以想分享出来我的理解。
简单说这两行代码的区别是,第一行代码是生成一个对象;第二行是两个对象。这便是不同之处。
具体分析如下:
第一行代码:
首先在 栈 中开辟一个空间存放一个 s1 引用。然后在java的方法区中的常量池开辟空间建立存放一个String类型的"abc"(假设之前常量池为空;因为如果之前有"abc"的话,就不会重新建立),引用 s1 指向池中的"abc",此时 s1 存放的是"abc"的地址。
第二行代码:
首先在 栈 中开辟一个空间存放一个 s2 引用。Java中,只要使用new关键字来创建对象,则一定会在堆区创建一个新的对象。然后,在堆中开辟空间建立了new String对象,这是一个对象;然后在堆中建立了一个对象"abc"并放入这个new String对象里面。一共两个对象。此时 s2 指向这个new String的堆地址。
接着看着两行代码:
String st1 = "abc";
System.out.println(st1 == "abc");
String st2 = new String("abc");
String.out.println(st2 == "abc");
//输出结果 ture false
我的理解如上。
如果哪里不正确,还希望各位看到这篇博客的朋友能指出来。