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) 已弃用

C# String与string的区别

Scala RDD[(String,String)] 到 RDD[String]

在JS中String 和string啥区别?