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

大部分人对原反补码的解释一般都是同样的一句话:所有的数在计算机里都是以补码的形式存放的,正数的

码就是正数的原码,负数的补码就是原码取反加1,然后他们还不忘加一句这是因为计算机中的四则运算都是以

法来实现的,用补码则方便了四则运算,这种理论还需要大家都说吗,随便看一下资料就知道了。而且大家也不

喜欢深究里面的原理,作为初学者的我对里面的原理也没有太过深究,下面的认识是我对学习过程中碰到的并查找

资料总结出来的一点东西。

不知道你们想过没,既然是以补码存放,那int a = -1;和int b = ox80000001;有什么区别吗。-1的原码就

ox80000001呀。下面为测试内容

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

显示结果为


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


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


再以十六进制输出看看


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


这又是为什么呢?第一个输出的明显是-1的补码,第二个为什么还是原来的数呢?(16进制输出不会区分符号位)

解释:当我们存数进去的时候,确实都是以补码的形式存在计算机里面,第二个b的赋值的时候若你前面没有负

号,它是不会看你的符号位的,就直接把它当做补码存进了计算机里面(正数的补码跟本身一样)。而当你以%d的

形式显示在屏幕上的时候,编译器才会检查补码的最高位,看是正数还是负数,正数就计算出它对应的十进制数输

出,负数就对补码做取反加以的操作,然后再计算出它的原码的十进制数再输出到屏幕上。这样就可以解释为什么

ox80000001以%d的形式输出的时候为-2147483647 = 0x7fffff(把0x80000001取反然后再加1).




了四则,这理论还需要大家都说吗,随便看一下资料就知道了,而且大家也不喜欢深究里面的原理。