大数操作(BigInteger、BigDecimal)
大数操作:正常情况下一个整数最多只能放在long类型之中,但是现在如果有以下一个数字:11111111111111111111111111111111111111111
根本是无法保存的,所以为了解决这种问题,在java中引入了两个大数的操作类:
·操作整型:BigInteger
·操作小数:BigDecimal
BigInteger
如果在操作的时候一个整型数据已经超过了整数的最大类型long的话,则此数据就无法装入,所以此时就要使用BigDecimal类进行操作。
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包中的。主要的功能可以实现数组元素的查找,数组内容的填充、排序等。
代码如下:
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));
}
}