RFR: 8310813: Simplify and modernize equals, hashCode, and compareTo for BigInteger [v10]
Pavel Rappo
prappo at openjdk.org
Tue Jan 2 14:37:27 UTC 2024
> Please review this PR to use modern APIs and language features to simplify equals, hashCode, and compareTo for BigInteger. If you have any performance concerns, please raise them.
>
> This PR is cherry-picked from a bigger, not-yet-published PR, to test the waters. That latter PR will be published soon.
Pavel Rappo 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 17 additional commits since the last revision:
- Merge branch 'master' into 8310813
- Merge branch 'master' into 8310813
- Merge branch 'master' into 8310813
- Merge branch 'master' into 8310813
- Fix bugs in Shared.createSingle
- Merge branch 'master' into 8310813
- Group params coarser (suggested by @cl4es)
- Splits 20 params into 3 groups: (S)mall, (M)edium and (L)arge.
Every testXYZ method invokes M operations, where M is the maximum
number of elements in a group. Shorter groups are cyclically padded.
- Uses the org.openjdk.jmh.infra.Blackhole API and increases
benchmark time.
- Fixes a bug in Shared that precluded 0 from being in a pair.
- Use better overloads (suggested by @cl4es)
- Uses simpler, more suitable overloads for the subrange
starting from 0
- Improve benchmarks
- Merge branch 'master' into 8310813
- ... and 7 more: https://git.openjdk.org/jdk/compare/cd913e32...252b7378
-------------
Changes:
- all: https://git.openjdk.org/jdk/pull/14630/files
- new: https://git.openjdk.org/jdk/pull/14630/files/ef8b0c46..252b7378
Webrevs:
- full: https://webrevs.openjdk.org/?repo=jdk&pr=14630&range=09
- incr: https://webrevs.openjdk.org/?repo=jdk&pr=14630&range=08-09
Stats: 4826 lines in 316 files changed: 2898 ins; 812 del; 1116 mod
Patch: https://git.openjdk.org/jdk/pull/14630.diff
Fetch: git fetch https://git.openjdk.org/jdk.git pull/14630/head:pull/14630
PR: https://git.openjdk.org/jdk/pull/14630
More information about the core-libs-dev
mailing list