Java基础提高 String与String.intern()

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/immrwk/article/details/80226112

首先看一段代码,思考运行结果

String s0 = new String("ab");
String s1 = new String("ab");
String s2 = "ab";
String s3 = "a" + "b";
String s4 = "b";
String s5 = "a" + s4;

System.out.println(s1.intern() == s0);//判断1
System.out.println(s1.intern() == s2);//判断2
System.out.println(s1.intern() == s3);//判断3
System.out.println(s1.intern() == s5);//判断4
System.out.println(s1.intern() == s0.intern()); //判断5

我们先来了解以下几点:

1.String不是基本数据类型,是一个类,对象默认值为null
2.常量池(constant pool)指的是在编译期被确定,并被保存在已编译的.class文件中的一些数据。它包括了关于类、方法、接口等中的常量,也包括字符串常量。
3.一个字符串由多个字符串常量拼接而成,那么它也是字符串常量
4.Java会确保字符串常量只有一个拷贝
5.存在于.class文件中的常量池,在运行期被JVM装载,并且可以扩充。String的intern()方法就是扩充常量池的一个方法;当一个String实例str调用intern()方法时,Java查找常量池中是否有相同Unicode的字符串常量,如果有,则返回其的引用,如果没有,则在常量池中增加一个Unicode等于str的字符串并返回它的引用

下面我们重新看上面的那段代码
1.s1.intern()代表常量池中”ab”的引用,s2、s3、s4都是在编译时期被确定的字符串常量,所以也存在于常量池中,所以判断2、判断3结果为true。
2.s0、s1是new出来的,不是编译时期确定的,所以创建的字符串不存在于常量池中,所以判断1为false。
3.s5是运行时确定的,不能直接引用常量池中的”ab”,所以判断4为false
4.判断5中s1.intern()和s0.intern()引用的都是常量池中的”ab”,所以结果为true

猜你喜欢

转载自blog.csdn.net/immrwk/article/details/80226112