5、Java 命令式编程实用指南

Java 命令式编程实用指南

1. 数值计算与精度问题

在 Java 编程里,数值计算会碰到精度方面的问题。像在处理大数值相乘时,不同的写法会有不同的结果:

System.out.println( 1_000_000 * 1_000_000L );
System.out.println( 1_000_000L * 1_000_000 );
System.out.println( 1_000_000L * 1_000_000L );
System.out.println( (long) 1_000_000 * 1_000_000 );
System.out.println( 1_000_000 * (long) 1_000_000 );

而在处理浮点数相加时, double 类型无法精确表示 0.1 这样的数字。 0.1 在 IEEE - 754 格式里的位模式对应的值是 0.100000001490116119384765625 ,误差约为 1.49 × 10−9 。把这个值加十次,结果不会是 1.0 。解决这个问题有几种办法:
- 用 BigDecimal 类来替代 double
- 接受这种不精确性,在输出时进行四舍五入,可借助 printf(…) 实现。
- 把货币金额以美分形式存储,比如不存

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值