1.为什么不是1.51?输出的是1.50
2.decimalformat括号里的字符串代表了什么意思?有模板吗?如果是别的格式应该怎么写
3.为什么要用#号而不是0.00?如果是#好的话,当a是0.505的时候有bug
double a =1.505;
BigDecimal bd = new BigDecimal(a);
System.out.println(new DecimalFormat("#.00").format(bd));
高洛峰2017-04-18 10:53:52
首先,指出一个问题:构建 BigDecimal
的时候,尽量不要使用浮点数(double
,float
),因为浮点数在计算机中的存储存在精度缺失问题。比如你的写的代码:
public static void main(String[] args) throws Exception {
double a = 1.505;
BigDecimal bd = new BigDecimal(a);
System.out.println("bd: " + bd.toString());
}
运行结果:
可以看到,浮点数 1.505 在计算机中没法存储的 —— 具体原因如果不知道,请自行搜索 “浮点数精度缺失问题”
第二,如果需要输出 1.51,即常说的 “四舍五入”,那么需要指定 DecimalFormat
的舍入模式:
public static void main(String[] args) throws Exception {
BigDecimal bd = new BigDecimal("1.505");
System.out.println("bd: " + bd.toString());
DecimalFormat df = new DecimalFormat("#.00");
df.setRoundingMode(RoundingMode.HALF_UP);
System.out.println("format: " + df.format(bd));
}
运行结果:
如果不了解 RoundingMode
的用法,请自行搜索 “RoundingMode 的用法”
第三,关于 DecimalFormat
括号里的字符串代表的意思,请自行搜索 “DecimalFormat 的用法”