c/c++ uin32相乘赋值给uint64的变量精度丢失

有一个uint32_t的整数1611660692,将其乘1000后,发现得到的数值为1047956000,而不是1611660692000。过程如下

uint32_t a = 1611660692;
uint64_t b = a * 1000;

这种情况下,得到b的值为1047956000。右边先将结果转换为uint32_t的,再将uint32_t转换为uint64_t的,所以造成精度丢失。
如果像下边这么写就没问题了

uint32_t a = 1611660692;
uint64_t b = static_cast<uint64_t>(a)  * 1000;

得到b的值为1611660692000,是正确结果

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值