RFR: 8346567: Make Class.getModifiers() non-native [v2]

Dean Long dlong at openjdk.org
Wed Feb 5 20:26:16 UTC 2025


On Wed, 5 Feb 2025 19:42:02 GMT, Coleen Phillimore <coleenp at openjdk.org> wrote:

>> test/micro/org/openjdk/bench/java/lang/reflect/Clazz.java line 73:
>> 
>>> 71:     public int getAppArrayModifiers() {
>>> 72:         return clazzArray.getClass().getModifiers();
>>> 73:     }
>> 
>> I'm guessing this is the benchmark that shows an extra load.  How about adding a benchmark that makes the Clazz[] final or @Stable, and see if that makes the extra load go away?
>
> Name                      Cnt  Base   Error   Test   Error  Unit  Change
> getAppArrayModifiers       30 0.923 ± 0.004  1.260 ± 0.001 ns/op   0.73x (p = 0.000*)
> getAppArrayModifiersFinal  30 0.922 ± 0.000  1.260 ± 0.001 ns/op   0.73x (p = 0.000*)
> 
> No it doesn't really help.  There's still an extra load.

OK, if the extra load turns out to be a problem in the future, we could look into why the compilers are generating the load when the Class is known/constant.  If the old intrinsic was able to pull the constant out of the Klass, then surely we can do the same and pull the value from the Class field.

-------------

PR Review Comment: https://git.openjdk.org/jdk/pull/22652#discussion_r1943616021


More information about the core-libs-dev mailing list