您的位置:首页 > 其它

二进制

2015-10-21 15:52 204 查看
原码 1000 0001 (其中第一个1为符号位)
反码 1111 1110 (符号位不变,其余的取反)
补码 1111 1111 (原码取反+1 ,符号位不变) 计算机中一般使用补码表示 因为补码进行+-*/运算后 结果仍为补码

不管是在32还是在64位编译器处理下,int都是4字节32位,所以整数范围是- 2147483648~2147483647。

计算机负数是以其正数的原码的补码形式存储的,则有2147483648=231的原码为10...0(31个0),其反码为01...1(31个1),所以-2147483648表示为补码是反码加1为10...0(31个0)。因此:

1、~i:取反操作,为01...1(31个1),即231-1=2147483647;

2、 -i:相当于求其补码,取反,再加1。取反, 10...0(31个0)-> 01...1(31个1),再加1, 10...0(31个0),该二进制表现出来仍旧为- 2147483648;

3、1-i:即-i加1,因为不会溢出,直接加减法就行(当然二进制加减也不会错只是要注意负数是补码表示的),-2147483648+1=- 2147483647, 其实-2147483647的二进制形式也就是 10...0(31个0)+1= 10...01(30个0);

4、 -1-i:即-i减1,因为会溢出,所以还是要二进制加减,则为 10...0 (31个0)-1= 01...1(31个1),即 2 31-1=2147483647。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  二进制