有符号数,取绝对值后再赋值给有符号数,会有bug吗?

2020-01-21 21:30发布

int ia,ib;
long la;
..........
ia = abs(ia);
ib = abs(ib);
la= ia+ib;
........

本意是要得到 ia与ib的绝对值之和,这样能得到正确的结果吗?
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
20条回答
v灰尘
1楼-- · 2020-01-23 23:58
agilityChen 发表于 2015-1-10 11:40
问题大得很。
每一句代码都有问题:
(1) ia = abs(ia); ib = abs(ib);

“(2) la= ia+ib;
(ia + ib)的类型是int,赋值给Ia时,才转为long。
如果ia + ib已经超过32767或者-32768,就溢出了。
改为Ia = (long)ia + ib才不会有问题。”

在CW下试了一下,没有发现这个问题,就算超过了范围, ia+ib和 (long)ia + ib的结果是一样的。
--------------------------------------------------------------------------------------------------------------------------------
又试了一下,

12.jpg (276.72 KB, 下载次数: 0)

下载附件

2015-1-10 14:58 上传



我猜,和累加器有关,只要结果不超过累加器的范围(位数),就不会出问题。
biansf2001
2楼-- · 2020-01-24 02:50
有可能是负数哦亲,溢出就是负数了

一周热门 更多>