RFR: 8320759: Creation of random BigIntegers can be made faster
Brian Burkhalter
bpb at openjdk.org
Mon Nov 27 22:37:07 UTC 2023
On Sun, 26 Nov 2023 16:52:40 GMT, fabioromano1 <duke at openjdk.org> wrote:
> A faster and simpler way to generate random BigIntegers, avoiding eventually trimming of leading zeros in magnitude array.
src/java.base/share/classes/java/math/BigInteger.java line 732:
> 730: */
> 731: public BigInteger(int numBits, Random rnd) {
> 732: // randomBits() returns a zero length array if len == 0
Should this comment say "if numBits == 0"?
src/java.base/share/classes/java/math/BigInteger.java line 754:
> 752: // numInts >= 1, since numBits > 0
> 753:
> 754: int firstInt = rnd.nextInt() & (-1 >>> -numBits); // Mask out any excess bits
Instead of `numBits`, shouldn't this use something like `excessBits` similar to line 760 in the old version?
-------------
PR Review Comment: https://git.openjdk.org/jdk/pull/16817#discussion_r1406843451
PR Review Comment: https://git.openjdk.org/jdk/pull/16817#discussion_r1406847756
More information about the core-libs-dev
mailing list