Commit 40467606 by Per Bothner Committed by Per Bothner

BigInteger.java (init(int,Random)): New method.


	* java/math/BigInteger.java (init(int,Random)):  New method.
	Move body of constructor <init>(int,Random)) here.
	Re-write it to avoid constructing unneeded temporaries.
	(<init>(int,int,Random)):  Use new init method to avoid constructing
	extra temporary BigIntegers.

From-SVN: r45240
parent 967603ef
2001-08-28 Per Bothner <per@bothner.com>
* java/math/BigInteger.java (init(int,Random)): New method.
Move body of constructor <init>(int,Random)) here.
Re-write it to avoid constructing unneeded temporaries.
(<init>(int,int,Random)): Use new init method to avoid constructing
extra temporary BigIntegers.
2001-08-27 Tom Tromey <tromey@redhat.com>
* java/rmi/activation/Activatable.java,
......
......@@ -144,20 +144,36 @@ public class BigInteger extends Number implements Comparable
public BigInteger(int numBits, Random rnd)
{
this(1, randBytes(numBits, rnd));
if (numBits < 0)
throw new IllegalArgumentException();
init(numBits, rnd);
}
private static byte[] randBytes(int numBits, Random rnd)
private void init(int numBits, Random rnd)
{
if (numBits < 0)
throw new IllegalArgumentException();
int highbits = numBits & 31;
if (highbits > 0)
highbits = rnd.nextInt() >>> (32 - highbits);
int nwords = numBits / 32;
int extra = numBits % 8;
byte[] b = new byte[numBits / 8 + (extra > 0 ? 1 : 0)];
rnd.nextBytes(b);
if (extra > 0)
b[0] &= ~((~0) << (8 - extra));
return b;
while (highbits == 0 && nwords > 0)
{
highbits = rnd.nextInt();
--nwords;
}
if (nwords == 0 && highbits >= 0)
{
ival = highbits;
}
else
{
ival = highbits < 0 ? nwords + 2 : nwords + 1;
words = new int[ival];
words[nwords] = highbits;
while (--nwords >= 0)
words[nwords] = rnd.nextInt();
}
}
public BigInteger(int bitLength, int certainty, Random rnd)
......@@ -170,9 +186,7 @@ public class BigInteger extends Number implements Comparable
if (isProbablePrime(certainty))
return;
BigInteger next = new BigInteger(bitLength, rnd);
this.ival = next.ival;
this.words = next.words;
init(bitLength, rnd);
}
}
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment