赞
踩
运行0.1+0.2时,发现float和double的运算误差,由于float类型和douoble类型在运算时可能会有误差,需要使用java.math.BigDecimal类加以描述
public BigDecimal(String val){
}
add(BigDecimal augend)
BigDecimal b1 = new BigDecimal("0.1");
BigDecimal b2 = new BigDecimal("0.2");
BigDecimal b3 = b1.add(b2);
System.out.println(b3);
//0.3
//取出BigDecimal中的double
b3.doubleValue();
//MathContext指示小数长度
BigDecimal b3 = b1.add(b2, MathContext.DECIMAL32);
subtract(BigDecimal subtrahend)
divide(BigDecimal divisor)
BigDecimal b1 = new BigDecimal("1.5");
BigDecimal b2 = new BigDecimal("3");
BigDecimal b3 = b1.divide(b2);
System.out.println(b3);
//0.5
//计算4/3时,因为输出是无限循环小数而报错
multiply(BigDecimal multiplicand)
BigDecimal b1 = new BigDecimal("12.34");
BigDecimal b2 = new BigDecimal("11.11");
BigDecimal b3 = b1.multiply(b2, MathContext.DECIMAL32);
System.out.println(b3);
//137.0974
divide(BigDecimal divisor, int scale, RoundingMode roundingMode)
BigDecimal b1 = new BigDecimal("4");
BigDecimal b2 = new BigDecimal("3");
BigDecimal b3 = b1.divide(b2, 3, RoundingMode.DOWN);
System.out.println(b3);
//1.33
divideToIntegralValue(BigDecimal divisor, MathContext mc)
,返回商的整数解divideAndRemainder(BigDecimal divisor, MathContext mc)
,返回商和余数两个BigDecimal操作数remainder(BigDecimal divisor)
功能:求余,注意与模运算不同。当 x 和 y 的正负号一样的时候,两个函数结果是等同的;当 x 和 y 的符号不同时,rem 函数结果的符号和 x 的一样,而 mod 和 y 一样。
这是由于这两个函数的生成机制不同,rem 函数采用 fix 函数(向 0 方向舍入),而 mod 函数采用了 floor 函数(向无穷小方向舍入)
参考来源:https://www.runoob.com/w3cnote/remainder-and-the-modulo.html
BigDecimal b1 = new BigDecimal("-5.2");
BigDecimal b2 = new BigDecimal("2");
BigDecimal b3 = b1.remainder(b2);
System.out.println(b3);
//fix(-5.2/2) = -2; 5.2-(-2)*2 = -1.2
pow(int n, MathContext mc)
BigDecimal b1 = new BigDecimal("12.34");
BigDecimal b2 = new BigDecimal("11.11");
BigDecimal b3 = b1.pow(8, MathContext.DECIMAL32);
System.out.println(b3);
//5.376768E+8
negate()
plus()
,返回+thisround(MathContext mc)
public int compareTo(BigDecimal val)
BigDecimal b1 = new BigDecimal("3");
BigDecimal b2 = new BigDecimal("3");
int b3 = b1.compareTo(b2);
System.out.println(b3);
//3,3 -> 0
//2,3 -> -1
//4,3 -> 1
public boolean equals(Object x)
BigDecimal b1 = new BigDecimal("3");
BigDecimal b2 = new BigDecimal("3.00");
System.out.println(b1.equals(b2));
//false
public BigDecimal max(BigDecimal val)
BigDecimal b1 = new BigDecimal("3.5");
BigDecimal b2 = new BigDecimal("3");
BigDecimal b3 = b1.max(b2);
System.out.println(b3);
//3.5
//BigDecimal b3 = b1.min(b2);
public static BigDecimal valueOf(double val)
double val = 1.2222;
BigDecimal b1 = BigDecimal.valueOf(val);
System.out.println(b1);
public double doubleValue()
public BigDecimal movePointLeft(int n)
BigDecimal b1 = new BigDecimal("3.5");
BigDecimal b3 = b1.movePointLeft(8);
System.out.println(b3);
//3.5E-8
//BigDecimal b3 = b1.movePointLeft(8);
precision()
BigDecimal b1 = new BigDecimal("12.346");
System.out.println(b1.precision());
int scale()
BigDecimal b1 = new BigDecimal("-5.22323");
System.out.println(b1.scale());
//5
scaleByPowerOfTen(int n)
BigDecimal b1 = new BigDecimal("-5.22323");
BigDecimal b3 = b1.scaleByPowerOfTen(2);
System.out.println(b3);
//-522.323
setScale(int newScale, RoundingMode roundingMode)
BigDecimal b1 = new BigDecimal("-5.22323");
BigDecimal b3 = b1.setScale(2, RoundingMode.DOWN);
System.out.println(b3);
//-5.22
stripTrailingZeros()
BigDecimal b1 = new BigDecimal("-522000");
BigDecimal b2 = new BigDecimal("2.00");
BigDecimal b3 = b1.stripTrailingZeros();
BigDecimal b4 = b2.stripTrailingZeros();
System.out.println(b3);
//-5.22E5
System.out.println(b4);
//2
public BigDecimal ulp()
BigDecimal b1 = new BigDecimal("-12.324");
BigDecimal b2 = new BigDecimal("212120");
BigDecimal b3 = b1.ulp();
BigDecimal b4 = b2.ulp();
System.out.println(b3);
//0.001
System.out.println(b4);
//1
//"0" -> 1
//整数都是1
MathContext字段 | 有效数字 |
---|---|
DECIMAL32 | 7位 |
DECIMAL64 | 16位 |
DECIMAL128 | 34位 |
UNLIMITED | 无限 |
UP DOWN CEILING FLOOR HALF_UP HALF_DOWN HALF_EVEN UNNECESSARY
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。