神奇的java代码_java中神奇的String:用代码直接分析

public class Dome02 {

/**

* @param args

*/

public static void main(String[] args) {

// TODO Auto-generated method stub

/**

* 情景一:字符串池

* JAVA虚拟机(JVM)中存在着一个字符串池,其中保存着很多String对象;

* 并且可以被共享使用,因此它提高了效率。

* 由于String类是final的,它的值一经创建就不可改变。

* 字符串池由String类维护,我们可以调用intern()方法来访问字符串池。

*/

String s1 = "abc";

// 在字符串池创建了一个对象

String s2 = "abc";

// 字符串pool已经存在对象“abc”(共享),所以创建0个对象,累计创建一个对象

System.out.println("s1 == s2 : "+(s1==s2));

// true 指向同一个对象,

System.out.println("s1.equals(s2) : " + (s1.equals(s2)));

// true 值相等

//------------------------------------------------------over

/**

* 情景二:关于new String("")

*

*/

String s3 = new String("abc");

// 创建了两个对象,一个存放在字符串池中,一个存在与堆区中; ("abc")

// 还有一个对象引用s3存放在栈中

String s4 = new String("abc");

// 字符串池中已经存在“abc”对象,所以只在堆中创建了一个对象

System.out.println("s3 == s4 : "+(s3==s4));

//false s3和s4栈区的地址不同,指向堆区的不同地址;

System.out.println("s3.equals(s4) : "+(s3.equals(s4)));

//true s3和s4的值相同

System.out.println("s1 == s3 : "+(s1==s3));

//false 存放的地区多不同,一个栈区,一个堆区

System.out.println("s1.equals(s3) : "+(s1.equals(s3)));

//true 值相同

//------------------------------------------------------over

/**

* 情景三:

* 由于常量的值在编译的时候就被确定(优化)了。

* 在这里,"ab"和"cd"都是常量,因此变量str3的值在编译时就可以确定。

* 这行代码编译后的效果等同于: String str3 = "abcd";

*/

String str1 = "ab" + "cd"; //1个对象

String str11 = "abcd";

System.out.println("str1 = str11 : "+ (str1 == str11));

// true---------------------------------------------------over

/**

* 情景四:

* 局部变量str2,str3存储的是存储两个拘留字符串对象(intern字符串对象)的地址。

*

* 第三行代码原理(str2+str3):

* 运行期JVM首先会在堆中创建一个StringBuilder类,

* 同时用str2指向的拘留字符串对象完成初始化,

* 然后调用append方法完成对str3所指向的拘留字符串的合并,

* 接着调用StringBuilder的toString()方法在堆中创建一个String对象,

* 最后将刚生成的String对象的堆地址存放在局部变量str3中。

*

* 而str5存储的是字符串池中"abcd"所对应的拘留字符串对象的地址。

* str4与str5地址当然不一样了。

*

* 内存中实际上有五个字符串对象:

* 三个拘留字符串对象、一个String对象和一个StringBuilder对象。

*/

String str2 = "ab"; //1个对象

String str3 = "cd"; //1个对象

String str4 = str2+str3;

String str5 = "abcd";

System.out.println("str4 = str5 : " + (str4==str5));

// false---------------------------------------------------over

/**

* 情景五:

* JAVA编译器对string + 基本类型/常量 是当成常量表达式直接求值来优化的。

* 运行期的两个string相加,会产生新的对象的,存储在堆(heap)中

*/

String str6 = "b";

String str7 = "a" + str6;

String str67 = "ab";

System.out.println("str7 = str67 : "+ (str7 == str67));

//false------------str6为变量,在运行期才会被解析。

final String str8 = "b";

String str9 = "a" + str8;

String str89 = "ab";

System.out.println("str9 = str89 : "+ (str9 == str89));

//true-------------str8为常量变量,编译期会被优化

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值