进制
十进制D
十六进制H
二进制B
八进制O
/****************************************************/
带符号位二进制的减法运算
/****************************************************/
1. 将最高位定义为符号位(原码)
如果用以上的定义,在正负数相加时,无法满足要求。(如正5与负5的相加,最后无法得到0的结果)
/****************************************************/
2. 引入补码
二进制补码:
正数:与原码相同
负数:除符号位外,其他位取反加一
例如:补码为1000代表了-8
引入补码后再次计算(正5加负5)
00101+11011=00000(去掉最高位后,结果为0)
补码范围:例如四位,为-8(1000)到+7(0111)
不对称的原因由于+0和-0的补码相同(0000)
0~7 ,
-1~-8 共16位
注意点:
补码的位数扩展
正数,前边补0
负数,前边补1
/****************************************************/
*3. 结果
溢出
两个符号相反时不会溢出,符号相同时可能会溢出
判断标准:
进位位和符号位相反时,计算结果出错,产生溢出
溢出的本质是位数不够,在计算时就需要考虑计算所需要的位数
正常在加减中需要多增加一位来防止结果溢出
例如(6+2)
有符号位考虑下,正常用四位表示6和2
0110+0010=1000(是-8的补码)
因为最后正确结果8无法用四位表示(范围是-8~7)
进位位为0,符号位为1,判断溢出
需要增加一位
00110+00010=01000(是+8的补码)
结果正确