String.intern、new 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);


欢迎大神来指正错误

你可能感兴趣的:(java,字符串,String)