大数操作:正常情况下一个整数最多只能放在long类型之中,但是现在如果有以下一个数字:11111111111111111111111111111111111111111
根本是无法保存的,所以为了解决这种问题,在java中引入了两个大数的操作类:
·操作整型:BigInteger
·操作小数:BigDecimal
如果在操作的时候一个整型数据已经超过了整数的最大类型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]); } }
使用此类可以完成大的小数操作,而且也可以使用此类进行精确的四舍五入。这点在开发中会经常用到。对于不需要任何准确计算精度的程序可以直接使用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表示操作数组的类,是直接定义在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)); } }