正数
正数的原码就是该数的二进制表现形式,正数的反码,补码与原码一致
如:56的原码:0011 1000
56的反码:0011 1000
56的补码:0011 1000
其中:0(符号位) 011 1000(数据),最高位为符号位,当符号位为0是正数,符号位为1是负数
最大值:0111 1111(+127)
最小值:1111 1111(-127)
负数
负数的原码转换形式:先将该负数的正数表现形式转换为二进制,将二进制的符号位变为1
如:-56转换为原码:
1,56的二进制表现形式:00111000
2,最高位变为1:10111000
负数的反码转换形式:负数的原码符号位不变,数值取反,0变为1,1变为0
如:10111000(十进制为56)转换为反码:11000111
负数的补码转换形式:将该负数的反码加1
如:11000111(56)转换为补码:11001000
补充:
1,负数的反码是为了解决原码不能计算负数的问题而出现的,负数的原码加1减1与产生的结果的原码不一致的问题
如:-1原码:1000 0001,-1减1=-2,但是原码1000 0001减1:1000 0000,结果为0
-1加1=0,但是原码1000 0001加1:1000 0010,结果为-2
利用反码,-1反码:1111 1110,-1减1=-2,反码1111 1110减1:1111 1101,转换为原码结果为-2
-1加1=0,反码1111 1110加1:1111 1111,转换为原码结果为0
2,负数的补码是为了解决正数与负数的计算跨0的问题。
负数的反码的0有两种表现形式,分别是:+0:0000 0000,-0:1111 1111,当负数的计算涉及到跨0时,就会有1的误差.比如:-5+7=2,跨0了,此时负数-5+7得到的反码是1
负数的补码是为了解决负数的计算涉及到跨0时,就会有1的误差这个问题。
负数的补码将补码错开一位,将-0反码(1111 1111)变为-1的补码,即负数的反码+1就会变成该负数的补码。如下图所示:
3,计算机中的存储和计算都是以补码的形式进行的
其他运算符
&:两边都为真结果才为真,只要有一个false结果就是false
|:两边都为false结果才为false,只要有一个true就是true
<<:左移一位相当于该数*2
》:右移一位相当于该数/2