[ 
https://issues.apache.org/jira/browse/CXF-3262?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Jason Downey updated CXF-3262:
------------------------------

    Attachment: patch.diff

Here's a potential patch for this issue. Now Literal and Variable have a create 
function which return a UriChunk. Variable creation avoids the throwing of 
IllegalArgumentException but Literal keeps it for null and blank strings.

In this tightly nested loop,

    public void testURITemplatePerformance() {
        long startTime = System.currentTimeMillis();
        for (long i = 1; i < 900000; i++)
            new URITemplate("/customers/name/{name}/dep/{department}");
        long endTime = System.currentTimeMillis();
        System.out.println(endTime - startTime);
    }

the original implementation ran in 26 seconds; the patched version ran in 13 
seconds. The savings would have been a lot more if there had been more literals 
in the URI.

> JAX-RS: Performance Improvement: Don't use IllegalArgumentException to 
> determine if a URI chunk is a variable or literal
> ------------------------------------------------------------------------------------------------------------------------
>
>                 Key: CXF-3262
>                 URL: https://issues.apache.org/jira/browse/CXF-3262
>             Project: CXF
>          Issue Type: Improvement
>          Components: JAX-RS
>    Affects Versions: 2.3.1
>         Environment: JDK 1.6
>            Reporter: Ka-Lok Fung
>            Priority: Minor
>             Fix For: 2.3.3
>
>         Attachments: patch.diff
>
>   Original Estimate: 3h
>  Remaining Estimate: 3h
>
> Profiling the Apache CXF JAX-RS code shows that more time than necessary is 
> being spent in UriChunk.createUriChunk because it uses an 
> IllegalArgumentException to determine whether a URI chunk should be a literal 
> or a variable. Creating exceptions is expensive :(
> Instead of using IllegalArgumentException, perhaps you can have a method that 
> is like the following:
> public static Variable.create(String uriChunk)
> where null will be returned if uriChunk is not a variable. This way you can 
> avoid the overhead of creating the unnecessary stack trace.

-- 
This message is automatically generated by JIRA.
-
You can reply to this email to add a comment to the issue online.

Reply via email to