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)修复的.
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |