java.math.BigInteger.shiftLeft(int n) 返回一個BigInteger,其值為(this<< n)。移位距離,在這種情況下,正也可能為負,這個方法執行右移。它計算 floor(this * 2n).
以下是java.math.BigInteger.shiftLeft()方法的宣告
public BigInteger shiftLeft(int n)
n - 移動距離,以位
該方法返回一個BigInteger物件的值是 this << n .
ArithmeticException - 如果移位距離為Integer.MIN_VALUE
下面的例子顯示math.BigInteger.shiftLeft()方法的用法
package com.yiibai; import java.math.*; public class BigIntegerDemo { public static void main(String[] args) { // create 3 BigInteger objects BigInteger bi1, bi2, bi3; bi1 = new BigInteger("10"); // perform leftshift operation on bi1 using 2 and -2 bi2 = bi1.shiftLeft(2); bi3 = bi1.shiftLeft(-2); String str1 = "Leftshift on " + bi1 + ", 2 times gives " +bi2; String str2 = "Leftshift on " + bi1 + ",-2 times gives " +bi3; // print bi2, bi3 values System.out.println( str1 ); System.out.println( str2 ); } }
讓我們編譯和執行上面的程式,這將產生以下結果:
Leftshift on 10, 2 times gives 40 Leftshift on 10,-2 times gives 2