数电--编码

进制

十进制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的补码)
结果正确

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值