1
2public static void main(String[] args) { String a = "a1"; String b = "a" + 1; System.out.println(a == b); }
3public static void main(String[] args) { String a = "ab"; String bb = "b"; String b = "a" + bb; System.out.println(a == b); }
4public static void main(String[] args) { String a = "ab"; final String bb = "b"; String b = "a" + bb; System.out.println(a == b); }
5public static void main(String[] args) { String a = "ab"; final String bb = getBB(); String b = "a" + bb; System.out.println(a == b); } private static String getBB() { return "b"; }
6private static String a = "ab"; public static void main(String[] args) { String s1 = "a"; String s2 = "b"; String s = s1 + s2; System.out.println(s == a); System.out.println(s.intern() == a); }
=========================================================================================================private static String a = new String("ab"); public static void main(String[] args) { String s1 = "a"; String s2 = "b"; String s = s1 + s2; System.out.println(s == a); System.out.println(s.intern() == a); System.out.println(s.intern() == a.intern()); }
3、六道题答案详解 1)true 要说明一点:当两个字符串字面值连接时(相加),得到的新字符串依然是字符串字面值,保存在常量池中。 2)false 当字符串字面值与String类型变量连接时,得到的新字符串不再保存在常量池中,而是在堆中新建一个String对象来存放。很明显常量池中要求的存放的是常量,有String类型变量当然不能存在常量池中了。 3)true 注意此题与上一题的区别,此处是字符串字面值与String类型常量连接,得到的新字符串依然保存在常量池中。 4)false 此题中第条语句:final String bb = getBB();其实与final String bb = new String(“b”);是一样的。也就是说return “b”会在堆中创建一个String对象保存”b”,虽然bb被定义成了final。可见并非定义为final的就保存在常量池中,很明显此处bb常量引用的String对象保存在堆中,因为getBB()得到的String已经保存在堆中了,final的String引用并不会改变String已经保存在堆中这个事实。 5)false,true 可能很多人对intern()这个函数不了解。JDK API文档中对intern()方法的描述是: 返回字符串对象的规范化表示形式。 一个初始为空的字符串池,它由类 String 私有地维护。 当调用 intern 方法时,如果池已经包含一个等于此 String 对象的字符串(用 equals(Object) 方法确定),则返回池中的字符串。否则,将此 String 对象添加到池中,并返回此 String 对象的引用。 它遵循以下规则:对于任意两个字符串 s 和 t,当且仅当 s.equals(t) 为 true 时,s.intern() == t.intern() 才为 true。 所有字面值字符串和字符串赋值常量表达式都使用 intern 方法进行操作。 上面字符串池即为字符串常量池。明白该题结果的原因了吧。 6)false,false,true
String 经典内存指向面试题
最新推荐文章于 2023-01-13 20:11:23 发布