
如何用C++进行整型数据溢出?
展开全部
C语言的整型溢出,分为无符号整型溢出和有符号整型溢出。
对于unsigned整型溢出,C的规范是有定义的——“溢出后的数会以2^(8*sizeof(type))作模运算”,也就是说,如果一个unsigned
char(1字符,8bits)溢出了,会把溢出的值与256求模。如:
1.unsigned
char
x
=
0xff;
2.printf("%dn",
++x);
上面的代码会输出:0
(因为0xff
+
1是256,与2^8求模后就是0)
对于signed整型的溢出,C的规范定义是“undefined
behavior”,也就是说,编译器爱怎么实现就怎么实现。如:
1.signed
char
x
=0x7f;
//注:0xff就是-1了,因为最高位是1也就是负数了
2.printf("%dn",
++x);
上面的代码会输出:-128,因为0x7f
+
0×01得到0×80,也就是二进制的1000
0000,符号位为1,负数,后面为全0,就是负的最小数,即-128。
对于unsigned整型溢出,C的规范是有定义的——“溢出后的数会以2^(8*sizeof(type))作模运算”,也就是说,如果一个unsigned
char(1字符,8bits)溢出了,会把溢出的值与256求模。如:
1.unsigned
char
x
=
0xff;
2.printf("%dn",
++x);
上面的代码会输出:0
(因为0xff
+
1是256,与2^8求模后就是0)
对于signed整型的溢出,C的规范定义是“undefined
behavior”,也就是说,编译器爱怎么实现就怎么实现。如:
1.signed
char
x
=0x7f;
//注:0xff就是-1了,因为最高位是1也就是负数了
2.printf("%dn",
++x);
上面的代码会输出:-128,因为0x7f
+
0×01得到0×80,也就是二进制的1000
0000,符号位为1,负数,后面为全0,就是负的最小数,即-128。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询