我们写程序中可能会经常碰到overflow的情形,其中对-2147483648的处理一不小心就会出现数据overflow。
-2147483648 = -2^31,我们知道这是64位系统中int型能表示的最小值,这个时候我们要小心对其进行操作,比如执行如下程序:
int a = -2147483648;
int b = a*-1;
int c = a-1;
可以发现结果为:
这是为什么呢?
先说c:
我们知道计算机加减运算时是采用补码的方式,所以-2147483648-1可以写成:
80000000+FFFFFFFF=7FFFFFFFF=2147483647;
再说b:
按道理b=-a=2147483648,但是很显然,它超出了int的表示范围,它的机器码为80000000,用补码理解即为-2147483648。
原文地址:http://blog.csdn.net/majing19921103/article/details/44863363