Uploaded image for project: 'Commons Text'
  1. Commons Text
  2. TEXT-153

LookupTranslator performance optimization

    XMLWordPrintableJSON

Details

    • Improvement
    • Status: Closed
    • Minor
    • Resolution: Fixed
    • 1.0
    • 1.7
    • None

    Description

      When using Java Mission Control to profile an application that uses StringEscapeUtils::escapeEcmaScript, I noticed that a lot of time is spent in LookupTranslator::translate at the prefixSet::contains check.

      I suggest taking advantage of the fact that prefixSet contains only characters, and replace it with a BitSet.

      I did some benchmarking and translate for the non escaped case is 4-5X faster when replacing the HashSet with a BitSet.

      BitSet Memory consumption for characters is capped at 8KB, and depends on the maximal prefix character. For example for ECMA script the max escaped prefix character is "\" which has unicode code 92 so the BitSet uses a long array of length 2 to represent all the needed characters.

       

      Link to pull request: https://github.com/apache/commons-text/pull/108

       

      Attachments

        Issue Links

          Activity

            People

              Unassigned Unassigned
              hermes Amir Hadadi
              Votes:
              0 Vote for this issue
              Watchers:
              2 Start watching this issue

              Dates

                Created:
                Updated:
                Resolved:

                Time Tracking

                  Estimated:
                  Original Estimate - Not Specified
                  Not Specified
                  Remaining:
                  Remaining Estimate - 0h
                  0h
                  Logged:
                  Time Spent - 1h 20m
                  1h 20m