--- old/src/java.base/share/classes/java/lang/invoke/SimpleMethodHandle.java 2017-07-17 19:04:11.000000000 -0700 +++ new/src/java.base/share/classes/java/lang/invoke/SimpleMethodHandle.java 2017-07-17 19:04:11.000000000 -0700 @@ -25,6 +25,8 @@ package java.lang.invoke; +import jdk.internal.vm.annotation.Stable; + import static java.lang.invoke.LambdaForm.BasicType.*; import static java.lang.invoke.MethodHandleStatics.*; @@ -41,10 +43,10 @@ return new SimpleMethodHandle(type, form); } - /*non-public*/ static final SpeciesData SPECIES_DATA = SpeciesData.EMPTY; + /*non-public*/ @Stable static BMHSpecies BMH_SPECIES; - /*non-public*/ public SpeciesData speciesData() { - return SPECIES_DATA; + /*non-public*/ public BMHSpecies speciesData() { + return BMH_SPECIES; } @Override @@ -58,18 +60,13 @@ } @Override - /*non-public*/ public int fieldCount() { - return 0; - } - - @Override /*non-public*/ final BoundMethodHandle copyWithExtendL(MethodType mt, LambdaForm lf, Object narg) { return BoundMethodHandle.bindSingle(mt, lf, narg); // Use known fast path. } @Override /*non-public*/ final BoundMethodHandle copyWithExtendI(MethodType mt, LambdaForm lf, int narg) { try { - return (BoundMethodHandle) SPECIES_DATA.extendWith(I_TYPE).constructor().invokeBasic(mt, lf, narg); + return (BoundMethodHandle) BMH_SPECIES.extendWith(I_TYPE_NUM).factory().invokeBasic(mt, lf, narg); } catch (Throwable ex) { throw uncaughtException(ex); } @@ -77,7 +74,7 @@ @Override /*non-public*/ final BoundMethodHandle copyWithExtendJ(MethodType mt, LambdaForm lf, long narg) { try { - return (BoundMethodHandle) SPECIES_DATA.extendWith(J_TYPE).constructor().invokeBasic(mt, lf, narg); + return (BoundMethodHandle) BMH_SPECIES.extendWith(J_TYPE_NUM).factory().invokeBasic(mt, lf, narg); } catch (Throwable ex) { throw uncaughtException(ex); } @@ -85,7 +82,7 @@ @Override /*non-public*/ final BoundMethodHandle copyWithExtendF(MethodType mt, LambdaForm lf, float narg) { try { - return (BoundMethodHandle) SPECIES_DATA.extendWith(F_TYPE).constructor().invokeBasic(mt, lf, narg); + return (BoundMethodHandle) BMH_SPECIES.extendWith(F_TYPE_NUM).factory().invokeBasic(mt, lf, narg); } catch (Throwable ex) { throw uncaughtException(ex); } @@ -93,7 +90,7 @@ @Override /*non-public*/ final BoundMethodHandle copyWithExtendD(MethodType mt, LambdaForm lf, double narg) { try { - return (BoundMethodHandle) SPECIES_DATA.extendWith(D_TYPE).constructor().invokeBasic(mt, lf, narg); + return (BoundMethodHandle) BMH_SPECIES.extendWith(D_TYPE_NUM).factory().invokeBasic(mt, lf, narg); } catch (Throwable ex) { throw uncaughtException(ex); }