原码,反码,补码表示法

首先,咱们引入一些相关的概念.编码

机器数: 数据在计算机中的表示形式。 数的符号存在最高位(左边),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,补码的表示惟一。

相关文章
相关标签/搜索