Java在java.math包中提供的API类BigDecimal,用来对超过16位有效位的数进行精确的运算。双精度浮点型变量double可以处理16位有效数。在实际应用中,需要对更大或者更小的数进行运算和处理。float和double只能用来做科学计算或者是工程计算,在商业计算中要用java.math.BigDecimal。BigDecimal所创建的是对象,我们不能使用传统的+、-、*、/等算术运算符直接对其对象进行数学运算,而必须调用其相对应的方法。方法中的参数也必须是BigDecimal的对象。构造器是类的特殊方法,专门用来创建对象,特别是带有参数的对象。
BigDecimal数据类型用于商业数据类型的计算。刚开始还在double +、-、*、/;感觉幼稚到爆了。
项目开发需计算月供本息合计的才认真研究了一下bigDecimal 的使用。
一般情况下:
一、 转换:
其他类型的数据转换成BigDecimal;
例如:
String value_1= “5000”;
BigDecimal mBigDecimal = new BigDecimal(value);
此时mBigDecimal 的值为5000.
其他数据类型转换成BigDecimal也可如此转换。
BigDecimal 的数据转换成String,int,double,
例如:
BigDecimal value_2=5000;
value_2.intValue(); 转成int.
value_2.doubleValue(); 转成double.
String.valueOf( value_2);转成String.
二、运算/小数点取值:
BigDecimal value_3 =5000;
BigDecimal value_4 =5000;
加: value_3.add(value_4);
减: value_3.subtract(value_4);
乘: value_3.multiply(value_4);
除: value_3.divide(value_4);
BigDecimal value_5 =5000.13;
BigDecimal value_6 =5000.62;
向上取整保留两位小数:
value_5.multiply(value_6).setScale(2,BigDecimal.ROUND_UP);
不保留小数位数 四舍五入 最终计算结果为整数:
value_5.multiply(value_6). setScale(0, BigDecimal.ROUND_HALF_UP);
格式化,相当于BigDecimal的正则:
BigDecimal value_7 =5000.1316;
BigDecimal value_8 =5000.000;
DecimalFormat mFormat = new DecimalFormat("###,###.000");
String a= mFormat.format(value_7);
String a = 5000.132;
DecimalFormat mFormat_2 = new DecimalFormat("###,###");
String b= mFormat_2.format(value_8);
String b=5000;
String c= mFormat_2.format(value_7);
String c=5000.132;
DecimalFormat mFormat_3 = new DecimalFormat("####,####");
String d = mFormat_3.format(value_7);
String d = 5000.1316;
String e = mFormat_3.format(value_8);
Strng e = 5000;