使用二进制计算的时候会出现溢出现象,是因为计算机都有它的上限和下限,太大的数值和太小的数值都是无法显示出来的。

计算机中用补码来表示和存储数值,而在进行数值的算术运算时由于机器字长的限制往往会出现补码溢出,导致计算结果错误。

针对这个问题,提出了一种根据溢出结果得到正确结果的计算方法:

两个正数相加溢出时,将错误解加上2~(n+1)即为正确解

两个负数相加溢出时,将错误解减去2~(n+1)即为正确解。