位置:首頁 > Java技術 > Java.math包 > Java.math.BigInteger.shiftLeft()方法實例

Java.math.BigInteger.shiftLeft()方法實例

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