double a=0.009;
double b=0.001;
System.out.print(a+b);//结果为0.009999999999999998
double 类型在进行运算的时候 会出现精度丢失的现象。要用java.math.BigDecimal
java在java.math包中提供的API类BigDecimal,用来对超过16位有效位的数进行精确的运算。双精度浮点型变量double可以处理16位有效数。在实际应用中,需要对更大或者更小的数进行运算和处理。float和double只能用来做科学计算或者是工程计算,在商业计算中要用java.math.BigDecimal。BigDecimal所创建的是对象,我们不能使用传统的+、-、*、/等算术运算符直接对其对象进行数学运算,而必须调用其相对应的方法。方法中的参数也必须是BigDecimal的对象
BigDecimal实例化方法
BigDecimal bd=new BigDecimal("1.11999");
System.out.println(bd);//1.11999
MathContext mc = new MathContext(2);//所有数字的长度不大于2
BigDecimal a= new BigDecimal("1.12345", mc);
System.out.println(a); //1.1
BigDecimal one=BigDecimal.ONE;
System.out.println(one);
BigDecimal zero=BigDecimal.ZERO;
System.out.println(zero);
BigDecimal ten=BigDecimal.TEN;
System.out.println(ten);
BigDecimal运算方法
加法:
MathContext mc=new MathContext(2);
BigDecimal a=new BigDecimal("1.223");
BigDecimal b=new BigDecimal("1.112");
System.out.println(a.add(b, mc));
减法:
MathContext mc=new MathContext(2);
BigDecimal a=new BigDecimal("4.66");
BigDecimal b=new BigDecimal("1.223");
System.out.println(a.subtract(b, mc));
乘法:
MathContext mc=new MathContext(2);
BigDecimal a=new BigDecimal("4.66");
BigDecimal b=new BigDecimal("1.223");
System.out.println(a.multiply(b, mc));
除法:
MathContext mc=new MathContext(2);
BigDecimal a=new BigDecimal("4.66");
BigDecimal b=new BigDecimal("1.223");
System.out.println(a.divide(b, mc));
System.out.println(a.divide(b,3,BigDecimal.ROUND_HALF_UP));//3位小数,四舍五入0.333
System.out.println(a.divide(b,3,BigDecimal.ROUND_UP));//3位小数,进位0.334
BigDecimal比较大小
BigDecimal a=new BigDecimal("4.66");
BigDecimal b=new BigDecimal("1.223");
System.out.println(a.compareTo(b));//a>b 结果1 a=b结果0 a<b 结果-1
BigDecimal a=new BigDecimal("1.0");
BigDecimal b=new BigDecimal("1");
System.out.println(a.compareTo(b));//a=b结果0
System.out.println(a.equals(b));//结果false
转载:http://blog.csdn.net/qq_21856521/article/details/72599604