RFR: 8277072: ObjectStreamClass caches keep ClassLoaders alive [v5]
    Roman Kennke 
    rkennke at openjdk.java.net
       
    Thu Dec  2 14:30:07 UTC 2021
    
    
  
> The caches in ObjectStreamClass basically map WeakReference<Class> to SoftReference<ObjectStreamClass>, where the ObjectStreamClass also references the same Class. That means that the cache entry, and thus the class and its class-loader, will not get reclaimed, unless the GC determines that memory pressure is very high.
> 
> However, this seems bogus, because that unnecessarily keeps ClassLoaders and all its classes alive much longer than necessary: as soon as a ClassLoader (and all its classes) become unreachable, there is no point in retaining the stuff in OSC's caches.
> 
> The proposed change is to use WeakReference instead of SoftReference for the values in caches.
> 
> Testing:
>  - [x] tier1
>  - [x] tier2
>  - [x] tier3
>  - [ ] tier4
Roman Kennke has updated the pull request incrementally with one additional commit since the last revision:
  Implement ClassCache: reclaim entries under memory pressure
-------------
Changes:
  - all: https://git.openjdk.java.net/jdk/pull/6375/files
  - new: https://git.openjdk.java.net/jdk/pull/6375/files/b7d53adc..570fac15
Webrevs:
 - full: https://webrevs.openjdk.java.net/?repo=jdk&pr=6375&range=04
 - incr: https://webrevs.openjdk.java.net/?repo=jdk&pr=6375&range=03-04
  Stats: 93 lines in 2 files changed: 89 ins; 0 del; 4 mod
  Patch: https://git.openjdk.java.net/jdk/pull/6375.diff
  Fetch: git fetch https://git.openjdk.java.net/jdk pull/6375/head:pull/6375
PR: https://git.openjdk.java.net/jdk/pull/6375
    
    
More information about the core-libs-dev
mailing list