On Thu, 19 Jun 2025 11:17:01 GMT, Kevin Walls <[email protected]> wrote:
>> Hashcode needs to be reset to -1 to force its recalculation on next call,
>> after deserialization.
>>
>> The change in the readResolve() method is the fix for this problem. While
>> here I added similar lines in other methods that may update fields (although
>> these are noted as not supported, as they change a class supposedly
>> "immutable").
>>
>> Added a test. There is a test for serialization for this class, but I found
>> it clearer to add the test for this specific recently discovered issue in
>> its own test file.
>
> Kevin Walls 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 six additional
> commits since the last revision:
>
> - Merge remote-tracking branch 'upstream/master' into
> 8358624_ImmutableDescriptor_hashcode
> - spelling
> - Exception name
> - whitespace
> - whitespace
> - 8358624: ImmutableDescriptor violates equals/hashCode contract after
> deserialization
src/java.management/share/classes/javax/management/ImmutableDescriptor.java
line 141:
> 139: bad = true;
> 140: if (!bad) {
> 141: hashCode = -1; // Force recalculation
Nit: Would it make sense to add same comment to the lines: 445, 452,473, 493?
-------------
PR Review Comment: https://git.openjdk.org/jdk/pull/25758#discussion_r2159391491