标签:
1、BigDecimal类概述
由于在运算的时候,float类型和double很容易丢失精度,演示案例。所以,为了能精确的表示、计算浮点数,Java提供了BigDecimal
不可变的、任意精度的有符号十进制数。
2、构造方法
public BigDecimal(String val):建议使用参数为字符串的构造方法,如果参数为double或float,还是会出现不可预知的精度问题
/** * 看程序写结果:结果和我们想的有一点点不一样,这是因为float类型的数据存储和整数不一样导致的。它们大部分的时候,都是带有有效数字位。 * 由于在运算的时候,float类型和double很容易丢失精度,演示案例。所以,为了能精确的表示、计算浮点数,Java提供了BigDecimal * BigDecimal类:不可变的、任意精度的有符号十进制数,可以解决数据丢失问题。 */ public class BigDecimalDemo01 { public static void main(String[] args) { //输出会出现精度问题 System.out.println(0.09 + 0.01); //0.09999999999999999 System.out.println(1.0 - 0.32); //0.6799999999999999 System.out.println(1.015 * 100); //101.49999999999999 System.out.println(1.301 / 100); //0.013009999999999999 System.out.println(1.0 - 0.12); //0.88 } }
举例2:
public class BigDecimalDemo02 { public static void main(String[] args) { BigDecimal bd1 = new BigDecimal("0.09"); BigDecimal bd2 = new BigDecimal("0.01"); System.out.println("add:"+bd1.add(bd2)); System.out.println("------------------"); BigDecimal bd3 = new BigDecimal("1.0"); BigDecimal bd4 = new BigDecimal("0.32"); System.out.println("subtract:"+bd3.subtract(bd4)); System.out.println("------------------"); BigDecimal bd5 = new BigDecimal("1.015"); BigDecimal bd6 = new BigDecimal("100"); System.out.println("multiply:"+bd5.multiply(bd6)); System.out.println("------------------"); BigDecimal bd7 = new BigDecimal("1.301"); BigDecimal bd8 = new BigDecimal("100"); System.out.println("divide:"+bd7.divide(bd8)); System.out.println("divide:" + bd7.divide(bd8, 3, BigDecimal.ROUND_HALF_UP)); System.out.println("divide:" + bd7.divide(bd8, 8, BigDecimal.ROUND_HALF_UP)); System.out.println("------------------"); } }
标签:
原文地址:http://www.cnblogs.com/yangyquin/p/5023996.html