A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© fanshuai 中级黑马   /  2015-2-19 15:02  /  926 人查看  /  3 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 fanshuai 于 2015-2-22 12:56 编辑

都是double 类型的值,怎么进行相减才能得到0.21?肯定有什么规则吧。

3 个回复

倒序浏览
double和float都有精度限制,尽管计算结果不一定“好看”,但精度一般来说够用了。如果要追求更高精度,可以用BigDecimal包,如果要追求结果“好看”,可以根据你要求的精度对操作数先放大再运算。比如1.21-1改成121-100,得到21后再除100变为0.21
回复 使用道具 举报
fantacyleo 发表于 2015-2-19 15:41
double和float都有精度限制,尽管计算结果不一定“好看”,但精度一般来说够用了。如果要追求更高精度,可 ...

惊现大神
回复 使用道具 举报
System.out.println((float)(b1-b2)),,,,,强转成float,因为double进度太高了
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马