BigDecimal和float相乘不能得到精确值详解编程语言

本文章主要介绍了BigDecimal和float相乘不能得到精确值,具有不错的的参考价值,希望对您有所帮助,如解说有误或未考虑完全的地方,请您留言指出,谢谢!

float numF = 1.2f; 
BigDecimal numDecimal = new BigDecimal(100); 
 
System.out.println(numDecimal.multiply(new BigDecimal(numF)));

result:

120.0000047683715820312500

原因是

System.out.println(new BigDecimal(numF));

result:

1.2000000476837158203125

改:

float numF = 1.2f; 
BigDecimal numDecimal = new BigDecimal(100);          
String numString = String.valueOf(numF); 
 
System.out.println(numDecimal.multiply(new BigDecimal(numString)));

result:

120.0

原创文章,作者:carmelaweatherly,如若转载,请注明出处:https://blog.ytso.com/228217.html

(0)
上一篇 2022年1月11日
下一篇 2022年1月11日

相关推荐

发表回复

登录后才能评论