补码减法运算

发布于 2022-09-06 22:43:03 字数 536 浏览 27 评论 0

考虑如下代码

#include <stdio.h>
#include <limits.h>
int compare (const void * a, const void * b)
{
    return ( *(int*)a - *(int*)b );
}

int main(void)
{
    int a = 1;
    int b = INT_MIN;
    printf("%d %d\n", a,b);
    printf("%d\n",compare((void *)&a,(void *)&b));
    return 0;
}

输出:
output is :
1 -2147483648
-2147483647
我知道INT_MIN是-2147483648,负数比整数表示的多一个,因此INT_MAX是2147483647,在网上搜索了补码的减法,A-B =A+(-B) ,等于A的补码加(-B)的补码,可是-B即2147483648已经超出了INT_MAX,所以这种情况下减法是如何进行的?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

命比纸薄 2022-09-13 22:43:03

溢出正是补码的一个特质,中间过程的溢出不会影响结果。

这里的结果溢出了,因为已经超出了正整数的表示范围(2147483649)。但是不是由于补码溢出导致的,而是在有限精度内的正常结果。

我还是举个例子吧。

2147483647 + 10 - 20

明显第一步的加法运算溢出了,但是最后我们还是会得到正确的2147483637。因为2147483647 + 10 = 2147483657 = -2147483639,而-2147483639 - 20 = -2147483659又会溢出,得到2147483637

一抹苦笑 2022-09-13 22:43:03

你问题是关于补码减法,例子里弄一堆指针转换有何意义?直接用

printf("%d\n", a - b);

不就把问题说清楚了么。

C里面忽略整数溢出错误。-INT_MIN用补码表示还是INT_MIN,其中的溢出被C忽略了。所以结果是1 + INT_MIN

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文