原码、反码、补码、移码的概念及转换

目录

前言

1.原码

2.反码

3.补码

4.移码 


前言

学习完数的小数点表示,下一个需要解决的问题就是数的机器码表示问题。

在计算机中对数据进行运算操作时,符号位应该如何表示?是否也同数值位一道参加运算操作呢?如果参加,会给运算操作带来什么影响呢?为了妥善处理好这些问题,就产生了把符号位和数值位一起编码来表示相应的数的各种表示方法,如原码补码反码移码。为了区别一般书写表示的数和机器中这些编码表示的数,通常将前者称为真值,后者称为机器数机器码

1.原码

表示:用机器数的最高位表示某个数的符号,其余的各位表示的绝对值。

示例:

 

注意:

若字长为n+1,则原码小数的表示范围为-(1-2^{^{-n}})≤x≤1-2^{^{-n}}

若字长为n+1,则原码整数的表示范围为-(2^n-1)≤x≤2^n-1。

真值零的原码表示有正零和负零两种形式。[+0]原 = 0000 / [-0]原 = 1000。

2.反码

表示:若为正数,则[x]反=[x]原。若为负数,则将该数原码的数值位全部取反。

示例:

 注意:

若字长为n+1,则反码小数的表示范围为-(1-2^{^{-n}})≤x≤1-2^{^{-n}}

若字长为n+1,则反码整数的表示范围为-(2^n-1)≤x≤2^n-1。

真值零的反码表示不唯一。[+0]反 = 0000 / [-0]反 = 1111。

3.补码

表示:对于正数,补码与原码的表示相同,[x]补=[x]原
对于负数,原码符号位不变,数值部分按位取反,末位加1。【此规则同样适用于由[x]补求[x]原】

示例:

 注意:

若字长为n+1,则补码小数的表示范围为-1≤x≤1-2^{^{-n}}

若字长为n+1,则补码整数的表示范围为-2^n≤x≤2^n-1。  

真值零的补码表示是唯一的。[+0]补 = [-0]补 = 0000。多出的1000(2)在十进制小数中可表示为-1,在整数中可表示为-2^n,如在8位补码中,1000000(2)表示数值-128(10)。

4.移码 

表示:补码基础上符号位取反。

示例:

 注意:移码只能用于表示整数。

  • 5
    点赞
  • 36
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Kk.巴扎嘿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值