最近准备面试,发现应届生考的比较多的就是基础,我面向c/c++,则做到的笔试题也有很多相关的题,其中就有charl类型变量a = 127 ,a+1 = ?的问题,这里记录一下自己的理解
我们知道char类型存储的值的范围是-128~127,127为正数的最大,再进行加一就会产生溢出操作:
计算机内部计算都是使用的二进制的补码进行计算:
127的二进制补码: 0 127+1后的二进制补码: 可以看出127 + 1 后的二进制码正好是规定的-128的二进制补码,所以打印结果就是-128
讯享网
同理,可以进行127 + 2的过程解释:
讯享网127的二进制补码:0 2的二进制补码:000000010 127 + 2: 0 +00000010 = 可以看到补码为-127的补码,所以127 + 2 = -127
从位扩展的角度解释:当127溢出时,就进行位数扩展,比如扩展成16位:
127的二进制原码:0 2的原码:00000010 127 + 2 会溢出 ,所以扩展位数: 127扩展后补码 : 00000000 0 2扩展后补码 : 00000000 00000010 127 + 2: 00000000 0 00000000 00000010 = 00000000 截取低八位: 为 -127补码
上面的解释是基于:
讯享网char a = 127; a++; printf("%d\n",a):
还有一种考法:
char a = 127; printf("%d\n",a+1);
这个对应的结果就是128,因为a+1表达式会先进行类型转换,char类型的a会转换为高级别的int类型,所以a = int(127),int类型为32位,+1后不会溢出,打印为128

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请联系我们,一经查实,本站将立刻删除。
如需转载请保留出处:https://51itzy.com/kjqy/67313.html