RFR 6642881: Improve performance of Class.getClassLoader()

Vladimir Ivanov vladimir.x.ivanov at oracle.com
Mon Jun 16 18:09:00 UTC 2014


Looks good.

Best regards,
Vladimir Ivanov

On 6/16/14 7:42 PM, Coleen Phillimore wrote:
> Summary: Add classLoader to java/lang/Class instance for fast access
>
> In order to improve performance of Class.getClassLoader() in a way to
> allow the compilers to automatically optimize this call, I added the
> classLoader to the instance of java/lang/Class.  For microbenchmarks,
> this results in a 98% improvement, which was expected.  For Oracle
> internal applications, this results in a 10-12% improvement on
> solaris/sparc.   The increase in size of java/lang/Class can be offset
> by other changes (removing constant pool lock, or removing signers).
>
> See bug link https://bugs.openjdk.java.net/browse/JDK-6642881 and
> associated linked bugs for more details.
>
> open webrev at http://cr.openjdk.java.net/~coleenp/6642881_hotspot/
> open webrev at http://cr.openjdk.java.net/~coleenp/6642881_jdk/
>
> There is both hotspot and jdk changes for this change.  The hotspot
> changes can work without the jdk changes (check for optional field), but
> not vice-versa.  I'll file another bug (and compatibility request) to
> remove JVM_GetClassLoader from hotspot.
>
> Tested with jck lang, vm, api/java_lang tests with/without jdk change,
> nsk vm.quick.testlist and hotspot jtreg tests, and jprt.
>
> Thanks,
> Coleen
>
>


More information about the jdk9-dev mailing list