您的位置:首页 > 编程语言 > C语言/C++

一个初学者的C语言学习之路——关于原反补码的一些认识

2017-07-03 17:21 393 查看
大部分人对原反补码的解释一般都是同样的一句话:所有的数在计算机里都是以补码的形式存放的,正数的
补码就是正数的原码,负数的补码就是原码取反加1,然后他们还不忘加一句这是因为计算机中的四则运算都是以
加法来实现的,用补码则方便了四则运算,这种理论还需要大家都说吗,随便看一下资料就知道了。而且大家也不
喜欢深究里面的原理,作为初学者的我对里面的原理也没有太过深究,下面的认识是我对学习过程中碰到的并查找
资料总结出来的一点东西。
不知道你们想过没,既然是以补码存放,那int a = -1;和int b = ox80000001;有什么区别吗。-1的原码就
是ox80000001呀。下面为测试内容



显示结果为



这不符合呀,为什么-1不能用原码存进去呢。-2147483647是怎么来的呢

再以十六进制输出看看



这又是为什么呢?第一个输出的明显是-1的补码,第二个为什么还是原来的数呢?(16进制输出不会区分符号位)
解释:当我们存数进去的时候,确实都是以补码的形式存在计算机里面,第二个b的赋值的时候若你前面没有负
号,它是不会看你的符号位的,就直接把它当做补码存进了计算机里面(正数的补码跟本身一样)。而当你以%d的
形式显示在屏幕上的时候,编译器才会检查补码的最高位,看是正数还是负数,正数就计算出它对应的十进制数输
出,负数就对补码做取反加以的操作,然后再计算出它的原码的十进制数再输出到屏幕上。这样就可以解释为什么
ox80000001以%d的形式输出的时候为-2147483647 = 0x7fffff(把0x80000001取反然后再加1).

了四则,这理论还需要大家都说吗,随便看一下资料就知道了,而且大家也不喜欢深究里面的原理。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: