String.internnew String()以及String =""总结:
Posted Chouney
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了String.internnew String()以及String =""总结:相关的知识,希望对你有一定的参考价值。
:jdk1.7之后将常量池移到了堆中,而不是在之前的方法区中首先最简单的new String("ss")即在堆中创建String对象,将"ss"字符常量传入并返回String对象在堆中的引用。
String="asd"总结:字符常量在编译期即被确定,会在常量池中创建其字符常量和地址(常量池是可以扩展的,即下面的String.inter()方法)
String.intern():会将当前String类型的值在常量池中对象做匹配,如果有,则返回常量池 首次出现的实例引用,如果没有,则在常量池中添加一个等于String值的字符串并返回其实例引用 简单的测试即: . String a = new String("123as");
System.out.println(a.intern()==a);//false
// 这里因为编译器在编译时将123as存到常量池中,因此a.intern返回的为123as对应引用,而不是a对象引用
PS:3个点需要关注: /* * 1. String a = new String("123as");
* String b = new String("qwe");
* String s3 = a+b;
* 此时常量池中存在"123as"与"qwe"两段,并在堆中创建"123asqwe"的String对象(因为a,b变量不是终态,所以无法编译器无法拼接两个字段到常量池中)
* 2. String a = new String("123as");
* String b = new String("qwe");
* String s3 = a+b;
* System.out.println(s3.intern()==s3); //true
* 此时s3.intern()会在常量池中添加该字符串并返回s3对象引用(因为"123asqwe"并不存在于常量池中)
* 3. String a = new String("123as");
* String b = new String("qwe");
* String s3 = a+b;
* (a+b).intern()==s3 //false
* 此时a+b会返回一个与s3不同的new String对象(虽然值相同)
*/
证明断言的测试用例: System.out.println(s3.intern()==s3); System.out.println((a+b).intern()==s3);
System.out.println(s3.intern()==a+b);
System.out.println((a+b).intern()==a+b);
欢迎大神来指正错误
以上是关于String.internnew String()以及String =""总结:的主要内容,如果未能解决你的问题,请参考以下文章
在 Spark Scala 中将 RDD[(String, String, String)] 转换为 RDD[(String, (String, String))]
“字符串”类型的参数不可分配给“$string”类型的参数 | `$string.$string` | `$string.$number`'
Activity 类型的方法 managedQuery(Uri, String[], String, String[], String) 已弃用