现在的位置: 首页 > 综合 > 正文

C语言有符号加减溢出

2019年04月22日 ⁄ 综合 ⁄ 共 531字 ⁄ 字号 评论关闭

sizeof(short int ) = 2;

测试用例

#include <stdio.h>
 
int main()
{
    short int a = -32768;
    short int b = 0x8000;
    short int c = 0xffff;
    short int d = 0x8001;
    printf("%d, %d, %d, %d\n", a, b, c, d);
    a -= 1;
    b -= 1;
    c -= 1;
    d -= 1;
    printf("%d, %d, %d, %d\n", a, b, c, d);
 
    return 0;
}

结果:

b, c, d的表示均为16进制表示,即机器的存储形式, 补码表示
负数溢出计算 
理解一:(按机器存储来看,存储均为补码形式)
a 的补码形式(存储形式)为 1000 0000 ... 0000       a-1机器存储为 01111...1  为 32767的补码
理解二:(如下图)
a为最大负数, a -1 = a+ 2^32 - 1  = -32768 + 65536 -1 = 32767

              图 一
b:  0xffff 为 -1的补码形式
补充:
short int 最大正数为 32767  
测试 37267 + 1 = 01111...1 +1 = 100...0  (为 -32768的补码)
所以
short int a = 32767;
a += 1;
printf("%d\n", a); // -32768 从 图 一 同样可以看出

抱歉!评论已关闭.