看朋友的BLOG,上面说double和float用于科学计算和工程计算,在商业上要使用BigDecimal,特别是由于精度问题和表示范围。
BigDecimal的其中两个构造函数的区别,
BigDecimal(double val)
Translates a double into a BigDecimal.
BigDecimal(String val)
Translates the String repre sentation of a BigDecimal into a BigDecimal.
用System.out.print(new BigDecimal(0.15));
结果是:0.1499999999999999944488848768742172978818416595458984375
用System.out.print(new BigDecimal("0.15"));
发现结果是:0.15
所以在使用包含小数的数据时尽量使用BigDecimal,并且用字符串来初始化它。
另一个小发现,自己一直没有注意到的,在编程时.1=0.1,0是可以省略掉的