RFR: 8320826: call allocate_shared_strings_array after all strings are interned

Calvin Cheung ccheung at openjdk.org
Tue Nov 28 21:24:04 UTC 2023


On Tue, 28 Nov 2023 04:09:52 GMT, Ioi Lam <iklam at openjdk.org> wrote:

> `StringTable::allocate_shared_strings_array()` creates a Java object array that has the exact same size as the number of currently interned strings. Therefore, we need to move it to just before we enter the safepoint, where we know no more Java code would be execute.
> 
> I also had to change the assert in `StringTable::allocate_shared_strings_array()` to a condition check:  it's possible for `HeapShared::init_for_dumping()` to disable heap dumping when a Java agent transforms classes like jdk.internal.math.FDBigInteger.

LGTM

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

Marked as reviewed by ccheung (Reviewer).

PR Review: https://git.openjdk.org/jdk/pull/16839#pullrequestreview-1753971340


More information about the hotspot-runtime-dev mailing list