RFR: 8377950: Refactor ClassUnloader to provide explicit waiting API

David Holmes dholmes at openjdk.org
Tue Feb 17 04:15:09 UTC 2026


On Mon, 16 Feb 2026 07:45:11 GMT, Albert Mingkun Yang <ayang at openjdk.org> wrote:

> Separates GC triggering from class reclamation waiting in vmTestbase ClassUnloader.
> 
> The original implementation used an implicit wait loop regardless of caller needs. Because the necessity of waiting is caller-specific, this PR introduces an explicit `unloadClassAndWait(timeout)` API. This allows callers to document their specific reasons for waiting (e.g., race conditions with JDWP or background compilation) while keeping `unloadClass()` simple for those who don't need to wait.
> 
> - Introduced `unloadClassAndWait(timeout)` and simplified `unloadClass()`.
> - Updated `compmethunload001` and `AbstractDebuggeeTest` to use the explicit waiting API with documented rationale.
> 
> Test: tier1-5, `vmTestbase/nsk`

Seems reasonable. A couple of minor comments.

Thanks

test/hotspot/jtreg/vmTestbase/nsk/jvmti/CompiledMethodUnload/compmethunload001.java line 97:

> 95: 
> 96:         // BackgroundCompilation is on by default so wait for compiler threads
> 97:         // to drop references to the to-be-unload class.

Suggestion:

        // to drop references to the to-be-unloaded class.

test/hotspot/jtreg/vmTestbase/nsk/jvmti/CompiledMethodUnload/compmethunload001.java line 98:

> 96:         // BackgroundCompilation is on by default so wait for compiler threads
> 97:         // to drop references to the to-be-unload class.
> 98:         if (!clsUnLoader.unloadClassAndWait(10_000)) {

Why 10_000 when the implicit timeout was 10 * 100 ?

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

PR Review: https://git.openjdk.org/jdk/pull/29735#pullrequestreview-3811557964
PR Review Comment: https://git.openjdk.org/jdk/pull/29735#discussion_r2814882058
PR Review Comment: https://git.openjdk.org/jdk/pull/29735#discussion_r2814890352


More information about the serviceability-dev mailing list