Real Life, Practical Example of Using String.intern() in Java?

后端 未结 5 1098
挽巷
挽巷 2021-01-01 11:47

I\'ve seen many primitive examples describing how String intern()\'ing works, but I have yet to see a real-life use-case that would benefit from it.

The only situati

相关标签:
5条回答
  • 2021-01-01 12:05

    We had a production system that processes literally millions of pieces of data at a time, many of which have string fields. We should have been interning strings, but there was a bug which meant we were not. By fixing the bug we avoided having to do a very costly (at least 6 figures, possibly 7) server upgrade.

    0 讨论(0)
  • 2021-01-01 12:06

    Not a complete answer but additional food for thought (found here):

    Therefore, the primary benefit in this case is that using the == operator for internalized strings is a lot faster than use the equals() method [for not internalized Strings]. So, use the intern() method if you're going to be comparing strings more than a time or three.

    0 讨论(0)
  • 2021-01-01 12:10

    Interning can be very beneficial if you have N strings that can take only K different values, where N far exceeds K. Now, instead of storing N strings in memory, you will only be storing up to K.

    For example, you may have an ID type which consists of 5 digits. Thus, there can only be 10^5 different values. Suppose you're now parsing a large document that has many references/cross references to ID values. Let's say this document have 10^9 references total (obviously some references are repeated in other parts of the documents).

    So N = 10^9 and K = 10^5 in this case. If you are not interning the strings, you will be storing 10^9 strings in memory, where lots of those strings are equals (by Pigeonhole Principle). If you intern() the ID string you get when you're parsing the document, and you don't keep any reference to the uninterned strings you read from the document (so they can be garbage collected), then you will never need to store more than 10^5 strings in memory.

    0 讨论(0)
  • 2021-01-01 12:11

    Never, ever, use intern on user-supplied data, as that can cause denial of service attacks (as intern()ed strings are never freed). You can do validation on the user-supplied strings, but then again you've done most of the work needed for intern().

    0 讨论(0)
  • 2021-01-01 12:18

    Examples where interning will be beneficial involve a large numbers strings where:

    • the strings are likely to survive multiple GC cycles, and
    • there are likely to be multiple copies of a large percentage of the Strings.

    Typical examples involve splitting / parsing a text into symbols (words, identifiers, URIs) and then attaching those symbols to long-lived data structures. XML processing, programming language compilation and RDF / OWL triple stores spring to mind as applications where interning is likely to be beneficial.

    But interning is not without its problems, especially if it turns out that the assumptions above are not correct:

    • the pool data structure used to hold the interned strings takes extra space,
    • interning takes time, and
    • interning doesn't prevent the creation of the duplicate string in the first place.

    Finally, interning potentially increases GC overheads by increasing the number of objects that need to be traced and copied, and by increasing the number of weak references that need to be dealt with. This increase in overheads has to be balanced against the decrease in GC overheads that results from effective interning.

    0 讨论(0)
提交回复
热议问题