1.背景
从文件读取多个字符串,存储起来供别的类来使用。
如果每次读入一个词都要new一个String,那么许多同样内容的String会创建很多次,这样会耗费大量内存。
如果使用set/map来去重的话,可以解决问题,但是效率会降低。这个时候最好使用String.intern()方法
2.使用
@Test
public void test()
{
String s = new String("abc");
String d = new String("abc");
System.out.println(s==d);
}
结果显然是:false
因为s,d是两个实例,在堆中地址不同,所以结果就为false
但是如果:
@Test
public void test()
{
String s = new String("abc").intern();
String d = new String("abc").intern();
System.out.println(s==d);
}
结果就是:true
3.原理
jvm中维护了一个String pool,里面保存了出现过的string对象。当调用intern()方法时,会先从string pool中通过equals方法查找是否出现过要创建的字符串,如果出现过,那么就直接返回string pool中的String对象,否则的话再new
另外,如果String直接指向字符串常量的时候,会自动调用intern()方法,这也就解释了为什么下面代码执行结果为true
@Test
public void test()
{
String s = "abc";
String d = "abc";
System.out.println(s==d);
}