Matcher performance improvements

Rémi Forax forax at univ-mlv.fr
Thu Aug 13 08:03:33 UTC 2009


Le 13/08/2009 03:30, Martin Buchholz a écrit :
> Hi regex/String team,
>
> We would like to contribute a performance improvement for Matcher.
>    

Just a minor comment, there is not @since 1.7

Rémi

> Please file a bug.
>
> category: java_util_regex
> Synopsis: Faster Matcher by replacing StringBuffer with StringBuilder
>
> Description:
> The old Matcher API and implementation depend on the old StringBuffer class.
> The use of StringBuilder gives measurable performance improvement in
> real world applications.
> http://cr.openjdk.java.net/~martin/webrevs/openjdk7/Matcher-perf/
> Written by Jeremy Manson.
>
> Here's a microbenchmark, where it gives 25% win:
>
> public class StringReplace {
>    static String jabber = "Twas brillig, and the slithy toves " +
>        "Did gyre and gimble in the wabe; " +
>        "All mimsy were the borogoves, " +
>        "And the mome raths outgrabe. " +
>        " " +
>        "Beware the Jabberwock, my son! " +
>        "The jaws that bite, the claws that catch! " +
>        "Beware the Jubjub bird, and shun " +
>        "The frumious Bandersnatch!" +
>        " " +
>        "He took his vorpal sword in hand: " +
>        "Long time the manxome foe he sought— " +
>        "So rested he by the Tumtum tree, " +
>        "And stood awhile in thought. " +
>        " " +
>        "And as in uffish thought he stood, " +
>        "The Jabberwock, with eyes of flame, " +
>        "Came whiffling through the tulgey wood, " +
>        "And burbled as it came! " +
>        " " +
>        "One, two! One, two! and through and through " +
>        "The vorpal blade went snicker-snack! " +
>        "He left it dead, and with its head " +
>        "He went galumphing back. " +
>        " " +
>        "And hast thou slain the Jabberwock? " +
>        "Come to my arms, my beamish boy! " +
>        "O frabjous day! Callooh! Callay!" +" " +
>        "He chortled in his joy. " +
>        " " +
>        "'Twas brillig, and the slithy toves " +
>        "Did gyre and gimble in the wabe; " +
>        "All mimsy were the borogoves, " +
>        "And the mome raths outgrabe?";
>
>    public static void replace() {
>      long start = System.currentTimeMillis();
>      for (int i = 0; i<  100000; i++) {
>        jabber.replaceAll("the", "ze");
>      }
>      long stop = System.currentTimeMillis();
>      System.out.println(stop);
>      System.out.println(start);
>
>      System.out.println(stop - start);
>    }
>
>    public static void main(String[] args) {
>      for (int i = 0; i<  5; i++) {
>        replace();
>      }
>    }
> }
>    




More information about the core-libs-dev mailing list