String中intern的方法

来源:互联网 发布:监控摄像头客户端软件 编辑:程序博客网 时间:2024/06/05 22:54
intern
public String intern()
返回字符串对象的规范化表示形式。
一个初始时为空的字符串池,它由类 String 私有地维护。
当调用 intern 方法时,如果池已经包含一个等于此 String 对象的字符串(该对象由 equals(Object) 方法确定),则返回池中的字符串。否则,将此 String 对象添加到池中,并且返回此 String 对象的引用。
它遵循对于任何两个字符串 s 和 t,当且仅当 s.equals(t) 为 true 时,s.intern() == t.intern() 才为 true。
所有字面值字符串和字符串赋值常量表达式都是内部的。
返回:

一个字符串,内容与此字符串相同,但它保证来自字符串池中。

String str1 = "a";String str2 = "b";String str3 = "ab";String str4 = str1 + str2;String str5 = new String("ab"); System.out.println(str5.equals(str3));System.out.println(str5 == str3);System.out.println(str5.intern() == str3);System.out.println(str5.intern() == str4);

得到的结果

truefalsetruefalse
为什么会得到这样的一个结果呢?我们一步一步的分析。
第一、str5.equals(str3)这个结果为true,不用太多的解释,因为字符串的值的内容相同。
第二、str5 == str3对比的是引用的地址是否相同,由于str5采用new String方式定义的,所以地址引用一定不相等。所以结果为false。
第三、当str5调用intern的时候,会检查字符串池中是否含有该字符串。由于之前定义的str3已经进入字符串池中,所以会得到相同的引用。
第四,当str4 = str1 + str2后,str4的值也为”ab”,但是为什么这个结果会是false呢?先看下面代码:
String a = new String("ab");String b = new String("ab");String c = "ab";String d = "a" + "b";String e = "b";String f = "a" + e;System.out.println(b.intern() == a);System.out.println(b.intern() == c);System.out.println(b.intern() == d);System.out.println(b.intern() == f);System.out.println(b.intern() == a.intern());
运行结果:
falsetruetruefalsetrue

由运行结果可以看出来,b.intern() == a和b.intern() == c可知,采用new 创建的字符串对象不进入字符串池,并且通过b.intern() == d和b.intern() == f可知,字符串相加的时候,都是静态字符串的结果会添加到字符串池,如果其中含有变量(如f中的e)则不会进入字符串池中。但是字符串一旦进入字符串池中,就会先查找池中有无此对象。如果有此对象,则让对象引用指向此对象。如果无此对象,则先创建此对象,再让对象引用指向此对象。
    当研究到这个地方的时候,突然想起来经常遇到的一个比较经典的Java问题,就是对比equal和==的区别,当时记得老师只是说“==”判断的是“地址”,但是并没说清楚什么时候会有地址相等的情况。现在看来,在定义变量的时候赋值,如果赋值的是静态的字符串,就会执行进入字符串池的操作,如果池中含有该字符串,则返回引用。
执行下面的代码:

String a = "abc";String b = "abc";String c = "a" + "b" + "c";String d = "a" + "bc";String e = "ab" + "c";        System.out.println(a == b);System.out.println(a == c);System.out.println(a == d);System.out.println(a == e);System.out.println(c == d);System.out.println(c == e);

运行的结果

truetruetruetruetruetrue

转:http://www.cnblogs.com/wanlipeng/archive/2010/10/21/1857513.html

        String s1 = "Test";        String s2 = "Test";        String s3 = new String("Test");        final String s4 = s3.intern();        System.out.println(s1 == s2);        System.out.println(s2 == s3);        System.out.println(s3 == s4);        System.out.println(s1 == s3);        System.out.println(" "+(s1 == s4));//True        System.out.println(s1.equals(s2));        System.out.println(s2.equals(s3));        System.out.println(s3.equals(s4));        System.out.println(s1.equals(s4));        System.out.println(s1.equals(s3));

结果

truefalsefalsefalse truetruetruetruetruetrue

测试每100万插入HashMap所消耗的时间

    private static void testMapInsertionIntern( final int cnt )    {        final Map<Integer, String> map = new HashMap<Integer, String>( cnt );//初始化大小        long start = System.currentTimeMillis();        for ( int i = 0; i < cnt; ++i )        {            final  String str = Integer.toString( i );            map.put( i, str.intern() ); //here is the difference!            if ( i % 1000000 == 0 ) //1M            {                System.out.println( i + "; time (intern) = " + ( System.currentTimeMillis() - start ) / 1000.0 + " sec" );                start = System.currentTimeMillis();            }        }        System.out.println( "Total length = " + map.size() );    }


原创粉丝点击