加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

java – 为什么HALF_UP有时会双倍倒圆?

发布时间:2020-12-15 00:58:16 所属栏目:Java 来源:网络整理
导读:以下代码: double doubleValue = 1713.6;float floatValue = 1713.6f;String fs = "%-9s : %-7s %-7sn";System.out.printf( fs,"","double","float" );DecimalFormat format = new DecimalFormat("#0");System.out.printf( fs,"toString",String.valueOf(
以下代码:
double doubleValue = 1713.6;
float floatValue = 1713.6f;
String fs = "%-9s : %-7s %-7sn";
System.out.printf( fs,"","double","float" );

DecimalFormat format = new DecimalFormat("#0");
System.out.printf( fs,"toString",String.valueOf( doubleValue ),String.valueOf( floatValue ) );

format.setRoundingMode( RoundingMode.DOWN );
System.out.printf( fs,"DOWN",format.format( doubleValue ),format.format( floatValue ) );

format.setRoundingMode( RoundingMode.HALF_DOWN );
System.out.printf( fs,"HALF_DOWN",format.format( floatValue ) );

format.setRoundingMode( RoundingMode.HALF_UP );
System.out.printf( fs,"HALF_UP",format.format( floatValue ) );

format.setRoundingMode( RoundingMode.UP );
System.out.printf( fs,"UP",format.format( floatValue ) );

产生结果(live code):

: double  float  
toString  : 1713.6  1713.6 
DOWN      : 1713    1713   
HALF_DOWN : 1714    1714   
HALF_UP   : 1713    1714   <--- notice this line
UP        : 1714    1714

我知道某些数字不能用浮点数表示. 1713.6的实际浮点数表示为1713.5999755859375(见this page).

但是为什么在这种情况下HALF_UP倒圆?

使用Java 1.8u25

解决方法

Java 8中有一个关于NumberFormat和RoundingMod HALF_UP的错误参见 8039915.这是用8u40( Release Notes)修复的.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读