what is the use of String.intern()

Collapse
X
 
  • Time
  • Show
Clear All
new posts
  • pjerald
    New Member
    • Oct 2007
    • 77

    what is the use of String.intern()

    what is the use of String.intern() . Is there any difference between a copy of a string object and the return value of this function ?
    This function also returns a copy of the string which it acts on. Clear me please.
  • JosAH
    Recognized Expert MVP
    • Mar 2007
    • 11453

    #2
    Originally posted by pjerald
    what is the use of String.intern() . Is there any difference between a copy of a string object and the return value of this function ?
    This function also returns a copy of the string which it acts on. Clear me please.
    When you use literal Strings in your program (and most likely you do), the javac
    compiler collects those strings. When you want to run your program those literal
    Strings are stored in a String pool. It stores just unique Strings in that pool, so:

    [code=java]
    String s1= "foo";
    String s2= "foo";
    [/code]

    This takes up one String in that pool: "foo" and both pointers s1 and s2 point to
    that single String. You can put Strings in that pool too by using the String.intern()
    method:

    [code=java]
    String s1= new String("foo");
    String s1= new String("foo");
    s1= s1.intern();
    s2= s2.intern();
    [/code]

    After the initialization s1 and s2 point to two different String instances, both
    having the value "foo". The literal String "foo" used for the instantiation of the
    Strings is stored in the String pool. After the initialization there are *three* strings
    "foo".
    After interning both Strings in the last two statements there's still one String "foo"
    in the String pool (because it already was there) and both references s1 and s2
    point to it. The two other String instantiations (that also contained "foo" but not
    the same as the one in the pool) can be garbage collected because nothing points
    to them anymore.

    When cleverly used that pool can save you quite a bit of memory.

    kind regards,

    Jos

    Comment

    • pjerald
      New Member
      • Oct 2007
      • 77

      #3
      Thanks a lot Jos. This is the first time I heared about the String pool and the particular job of the compiler regarding String.
      Thanks,
      P.Jerald.

      Comment

      • JosAH
        Recognized Expert MVP
        • Mar 2007
        • 11453

        #4
        Originally posted by pjerald
        Thanks a lot Jos. This is the first time I heared about the String pool and the particular job of the compiler regarding String.
        Thanks,
        P.Jerald.
        You're welcome of course; I should've mentioned one slight restriction: the Strings
        in that pool must have a length < 64KB; the bytes contain the UTF8 encoded
        version of the String. So if a String contains non-ASCII characters the maximum
        length is even less. (see the JVM specification (sorry, too lazy to search for a link ;-)

        kind regards,

        Jos

        Comment

        Working...