C语言数据溢出

C语⾔中的数据溢出

1、char是⼀个字节,8bit,在无符号unsigned char的数据类型的情况下,可表示2^8个数,其取值范围为 0-255 如果我们数据产⽣溢出(超过2^8)那么最终得到的结果将对2^8(256)取余。如:

unsigned char x = 0xff;

x++;

printf("%d\n",++x);

输出的结果将是1;⽽不是257.

2、对于signed的整数的溢出,C语⾔的定义是Undefined Overflow,也就是溢出的数正常显⽰,并不进⾏求余的运算。例如:

signed char x = 0xff

printf("%d\n",x);

0xff----> 1111 1111 数在计算机的内存中是以补码的形式存在,所以次数代表的数是:1000 0001也就是-1,所以输出是-1

signed char x = 0x7f

printf("%d\n",++x);

0x7f---->0111 1111 那么该数据先换算成正常的数再执⾏加1操作(整数的补码是本⾝),那么加1变成:1000 0000这是-128的补码但是我们知道在signed char的数据中⼀共有8位,并且符号占1位,那么有7位数,所以最⼤是:0111 1111也就是127,所以128是溢出,所以我们直接显⽰溢出的那个数,那么上⾯的代码输出就是-128.

你可能感兴趣的:(笔记,c语言,c++)