【计算机基础知识01】原码、反码、补码

1、前言-机器数和真值

我们首先要了解机器数和真值的概念。

1.1 机器数

一个数在计算机中的二进制表示形式,叫做这个数的机器数。机器数是带符号的,在计算机用一个数的最高位存放符号,正数为0,负数为1。
比如:十进制的数+3,计算机字长为8位,转换成二进制就是00000011,如果是-3,就是10000011.那么这里的00000011和10000011就是机器数
在这里插入图片描述

1.2 真值

真值可以理解为真正的值,一般用十进制表示,也可以用二进制表示。
因为第一位是符号位,所以机器数的形式值就不等于真正的数值。例如上面有
符号数10000011,其4最高位1代表负,其真正数值是-3而不是形式值131(10000011转换成十进制等于131).所以,为区别起见,将带符号位的机器数对应的真正数值称为机器数的真值。
例:00000001的真值为+1,10000001的真值为-1

2、原码

原码的表示:正数用0来表示,负数用1来表示,数值部分不变。

举例:0可表示为0000,-0为1000,-7为1111,5为0101(在此举例皆为4位原码)

缺点:0的表示不唯一,不利于编程;加减运算方式不统一,同号的数要比较绝对值才能做减法;额外的符号位不利于硬件设计。

3、反码

反码的表示:正数的反码是它本身;负数的原码是在其原码的基础上符号位不变,其余各位取反。

举例:+1的8位反码为00000001,-1的8位反码为11111110(-1的8位原码是10000001)

出现原因:反码的出现是为了解决原码做减法的问题。

4、补码

补码:正数的补码与原码一致,负数的补码是对原码按位取反加1,符号位不变。

5、计算示例

举例:+1的八位原码:0000 0001,补码:0000 0001

-1的原码:1000 0001,

补码:
第一步取反(实际是求补码):
1111 1110
第二步加1(补码的基础上加一):
1111 1111

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

山河不见老

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

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

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

打赏作者

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

抵扣说明:

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

余额充值