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

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

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

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

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

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

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

是ox80000001呀。下面为测试内容

 

具体输出结果如下:

 

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

 

再以十六进制输出看看

 

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

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

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

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

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

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

 

 

 

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值