大数操作(BigInteger、BigDecimal)

大数操作:正常情况下一个整数最多只能放在long类型之中,但是现在如果有以下一个数字:11111111111111111111111111111111111111111

根本是无法保存的,所以为了解决这种问题,在java中引入了两个大数的操作类:

·操作整型:BigInteger

·操作小数:BigDecimal

BigInteger

如果在操作的时候一个整型数据已经超过了整数的最大类型long的话,则此数据就无法装入,所以此时就要使用BigDecimal类进行操作。

java 大数库 java存大数_bi

BigInteger是在java.Math包中,下面是大数操作方法:

import java.math.BigInteger;
public class BigIntegerDemo
{
	public static void main(String args[]){
		BigInteger bi1=new BigInteger("12345345234234234234234234");
		BigInteger bi2=new BigInteger("123345345345345234234234");
		System.out.println("加法操作:"+bi1.add(bi2));
		System.out.println("减法操作:"+bi1.subtract(bi2));
		System.out.println("乘法操作:"+bi1.multiply(bi2));
		System.out.println("除法操作:"+bi1.divide(bi2));
		System.out.println("最大数:"+bi1.max(bi2));
		System.out.println("最小数:"+bi1.min(bi2));
		BigInteger result[]=bi1.divideAndRemainder(bi2);
		System.out.println("两数的商是:"+result[0]
			+"余数是"+result[1]);
	}
}

BigDecimal类

使用此类可以完成大的小数操作,而且也可以使用此类进行精确的四舍五入。这点在开发中会经常用到。对于不需要任何准确计算精度的程序可以直接使用float或double完成,但是如果需要精确计算结果,则必须使用BigDecimal类。

代码如下:

import java.math.* ;
class MyMath{
	public static double add(double d1,double d2){		// 进行加法计算
		BigDecimal b1 = new BigDecimal(d1) ;
		BigDecimal b2 = new BigDecimal(d2) ;
		return b1.add(b2).doubleValue() ;
	}
	public static double sub(double d1,double d2){		// 进行减法计算
		BigDecimal b1 = new BigDecimal(d1) ;
		BigDecimal b2 = new BigDecimal(d2) ;
		return b1.subtract(b2).doubleValue() ;
	}
	public static double mul(double d1,double d2){		// 进行乘法计算
		BigDecimal b1 = new BigDecimal(d1) ;
		BigDecimal b2 = new BigDecimal(d2) ;
		return b1.multiply(b2).doubleValue() ;
	}
	public static double div(double d1,double d2,int len){		// 进行乘法计算
		BigDecimal b1 = new BigDecimal(d1) ;
		BigDecimal b2 = new BigDecimal(d2) ;
		return b1.divide(b2,len,BigDecimal.ROUND_HALF_UP).doubleValue() ;
	}
	public static double round(double d,int len){	// 进行四舍五入
		BigDecimal b1 = new BigDecimal(d) ;
		BigDecimal b2 = new BigDecimal(1) ;
		return b1.divide(b2,len,BigDecimal.ROUND_HALF_UP).doubleValue() ;
	}
};

public class BigDecimalDemo01{
	public static void main(String args[]){
		System.out.println("加法运算:" + MyMath.round(MyMath.add(10.345,3.333),1)) ;
		System.out.println("减法运算:" + MyMath.round(MyMath.sub(10.345,3.333),3)) ;
		System.out.println("乘法运算:" + MyMath.round(MyMath.mul(10.345,3.333),2)) ;
		System.out.println("除法运算:" + MyMath.div(10.345,3.333,3)) ;
	}
};

对象克隆技术

对象克隆支持

对象克隆:对象的复制,完整的复制一个对象。

如果要想完成对象克隆的话,则肯定要依靠Object类。

protected Object clone() throws CloneNotSupportedException

以上的方法就是对象的克隆方法,如果现在一个类的对象被克隆,则就必须在类中明确的覆写此方法,但是此方法不能直接被调用。

Cloneable是一个接口,但是在此接口中并没有规定任何的操作方法,所以此接口实际上属于标识接口,标识一种能力。

代码如下:

class Person implements Cloneable	//实现Cloneable接口表示可以被克隆
{
	private String name;
	public Person(String name){
		this.name=name;
	}
	public void setName(String name){
		this.name=name;
	}
	public String getName(){
		return this.name;
	}
	public String toString(){
		return "姓名:"+name;
	}
	public Object clone() throws CloneNotSupportedException{
		return super.clone();		//具体的克隆操作由父类完成
	}
}
public class CloneDemo
{
	public static void main(String args[]) throws Exception{
		Person per1=new Person("张三");
		Person per2=(Person)per1.clone();
		per2.setName("李四");
		System.out.println("克隆前的对象:"+per1);
		System.out.println("克隆后的对象:"+per2);
	}
}

总结:在以后的java类库中会经常看到Cloneable接口的 出现,一定要记住:只有实现了此接口对象才可以被克隆,否则不可能实现克隆。

Arrays类

Arrays

Arrays表示操作数组的类,是直接定义在java.util包中的。主要的功能可以实现数组元素的查找,数组内容的填充、排序等。

java 大数库 java存大数_arrays_02

代码如下:

import java.util.Arrays;
public class ArraysDemo01
{
	public static void main(String args[]){
		int temp[]={1,-12,32,45,0};	//声明一个整型数组
		Arrays.sort(temp);
		for(int x:temp){
			System.out.print(x+"、");
		}
		System.out.println();
		System.out.println("排序后的数组字符串形式:"+Arrays.toString(temp));	//以字符串的形式输出数组
		//如果是想使用二分法查询的话,则必须是排序后的数组
		int point=Arrays.binarySearch(temp,12);	//检索位置
		System.out.println("元素'3'的位置在:"+point);
		Arrays.fill(temp,3);		//将数组里面的内容全部填充为3
		System.out.println("填充后的数组:"+Arrays.toString(temp));
	} 
}