您的位置:首页 > 其它

原码,反码,补码表示法

2014-01-30 17:10 537 查看
首先,我们引入一些相关的概念.

机器数: 数据在计算机中的表示形式。 数的符号存在最高位(左边),0代表正数,1代表负数。分成有符号和无符号两种。

A.对于无符号的数值,整个都是数值区。

B. 对于有符号的数值,数据分成两部分:符号位+数值区。

小数点:隐含表示,不占位置。

A. 对于无符号数值,小数点在最左边,代表是纯小数。在右边,代表纯整数。

B. 对于有符号的数值,小数点在数值区最左边,代表是纯小数。在数值区右边,代表纯整数。

真值:机器数对应的真实数值。

为了方便计算,带符号的机器数分成原码、反码和补码的不同编码方法。

1. 原码

左边的第一位表示符号(0为正,1为负), 其余位表示数值.

真值变成原码的转换方法:

(1)取真值的绝对值的2进制表示。

(2)左边第一位添加符号。

例如:

考虑一个字节的存储,-127, 绝对值为127的2进制表示为 0111 1111, 添加符号(1)为 1111 1111。

当真值=0的时候,[+0]原可以表示成 0000 0000, [-0]原可以表示成 1000 0000。

2. 反码

反码的表示方法是:

(1)如果是正数,反码与原码一样。

(2)如果是负数,反码是符号位不变,原码其余各个位取反.

例如:

[+127]原=0111 1111, [+127]反=0111 1111,

[-127]原=1111 1111, [-127]反=1000 0000。

[+0]原=0000 0000, [+0]反=0000 0000,

[-0]原=1000 0000, [-0]反=1111 1111。

3. 补码

补码表示方法:

(1)如果是正数, 补码与原码一样。

(2)如果是负数,在反码的基础上+1。

例如:

[+127]原=0111 1111, [+127]反=0111 1111,[+127]补=0111 1111

[-127]原=1111 1111, [-127]反=1000 0000,[-127]补=1000 0001

[+0]原=0000 0000, [+0]反=0000 0000,[+0]补=0000 0000,

[-0]原=1000 0000, [-0]反=1111 1111,[-0]补=0000 0000。

我们发现,原码、反码、补码对于正数和+0都是一样的。对于0,补码的表示唯一。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: