RFR: 8325949: Create an internal utility method for creating VarHandle instances [v5]
    Per Minborg 
    pminborg at openjdk.org
       
    Tue Sep 17 14:25:42 UTC 2024
    
    
  
> This PR suggests introducing an internal class in `java.base` to simplify the use of some `MethodHandles.Lookup` operations.
> 
> While the utility of the methods might appear to be limited in classes with many static `VarHandle`/`MethodHandle` variables, it should be noted that the class files become smaller and simpler. Here are some examples:
> 
> | Class File                                      | Base [Bytes] | Patch [Byte] |
> | --------------------------------| ------------- | ------------ |
> | FutureTask.class                          |            10,255 |          10,123 |
> | AtomicBoolean.class                   |             5,364 |            5,134 |
> |AtomicMarkableReference.class |             3,890 |           3,660 |
> 
> 
> 
> The new `MethodHandlesInternal.class` file is of size 1,952 bytes.
> 
> In total for `java.base` we have:
> 
> | Build map "jdk"  | Size [Bytes] |
> | ---------------| ------------- |
> | Base                 |     5,906,457 |
> | Patch                |     5,905,487 |
> | Delta                 |                940|
> 
> For 60 billion instances, this represents > 50 TB.
> 
> Tried and passed tier1-3
Per Minborg has updated the pull request with a new target base due to a merge or a rebase. The incremental webrev excludes the unrelated changes brought in by the merge/rebase. The pull request contains nine additional commits since the last revision:
 - Merge branch 'master' into internal-mh-util
 - Rename class and shorten JavaDoc
 - Update javadoc
 - Rename utility class
 - Move to new package and add overload
 - Merge branch 'master' into internal-mh-util
 - Rename and reformat
 - Fix copyright headers
 - Introduce MethodHandlesInternal
-------------
Changes:
  - all: https://git.openjdk.org/jdk/pull/20972/files
  - new: https://git.openjdk.org/jdk/pull/20972/files/7f140322..a1444c28
Webrevs:
 - full: https://webrevs.openjdk.org/?repo=jdk&pr=20972&range=04
 - incr: https://webrevs.openjdk.org/?repo=jdk&pr=20972&range=03-04
  Stats: 121988 lines in 261 files changed: 121641 ins; 172 del; 175 mod
  Patch: https://git.openjdk.org/jdk/pull/20972.diff
  Fetch: git fetch https://git.openjdk.org/jdk.git pull/20972/head:pull/20972
PR: https://git.openjdk.org/jdk/pull/20972
    
    
More information about the net-dev
mailing list