计算机基础上原码补码和反码,计算机基础理论:原码、反码、补码、移码

一、标准理论

1、原码的定义

①小数原码的定义

[X]原 =

X

0≤X <1

1- X

-1 < X ≤ 0

例如: X=+0.1011 , [X]原= 01011

X=-0.1011 [X]原= 11011

②整数原码的定义

[X]原 =

X

0≤X <2n

2n-X

- 2n < X ≤ 0

2、补码的定义

①小数补码的定义

[X]补 =

X

0≤X <1

2+ X

-1 ≤ X < 0

例如: X=+0.1011, [X]补= 01011

X=-0.1011, [X]补= 10101

②整数补码的定义

[X]补 =

X

0≤X <2n

2n+1+X

- 2n ≤ X < 0

3、反码的定义

①小数反码的定义

[X]反 =

X

0≤X <1

2-2n-1-X

-1 < X ≤ 0

例如: X=+0.1011 [X]反= 01011

X=-0.1011 [X]反= 10100

②整数反码的定义

[X]反 =

X

0≤X <2n

2n+1-1-X

- 2n < X ≤ 0

4.移码:移码只用于表示浮点数的阶码,所以只用于整数。

①移码的定义:设由1位符号位和n位数值位组成的阶码,则 [X]移=2n + X -2n≤X ≤ 2n例如: X=+1011 [X]移=11011 符号位“1”表示正号

X=-1011 [X]移=00101 符号位“0”表示负号

②移码与补码的关系: [X]移与[X]补的关系是符号位互为反码,

例如: X=+1011 [X]移=11011 [X]补=01011

X=-1011 [X]移=00101 [X]补=10101

③移码运算应注意的问题:

◎对移码运算的结果需要加以修正,修正量为2n ,即对结果的符号位取反后才是移码形式的正确结果。

◎移码表示中,0有唯一的编码——1000…00,当出现000…00时(表示-2n),属于浮点数下溢。

二、补码加、减运算规则

1、运算规则

[X+Y]补= [X]补+ [Y]补[X-Y]补= [X]补+ [-Y]补

若已知[Y]补,求[-Y]补的方法是:将[Y]补的各位(包括符号位)逐位取反再在最低位加1即可。

例如:[Y]补= 101101 [-Y]补= 010011

2、溢出判断,一般用双符号位进行判断:

符号位00 表示正数 11 表示负数

结果的符号位为01时,称为上溢;为10时,称为下溢

例题:设x=0.1101,y=-0.0111,符号位为双符号位

用补码求x+y,x-y

[x]补+[y]补=00 1101+11 1001=00 0110

[x-y]补=[x]补+[-y]补=00 1101+00 0111=01 0100

结果错误,正溢出

三、原码一位乘的实现:

设X=0.1101,Y=-0. 1011,求X*Y

解:符号位单独处理, x符+ y符数值部分用原码进行一位乘,如下图所示:

高位部分积

低位部分积/乘数

说明

0 0 0 0 0 0

1 0 1 1

起始情况

+) 0 0 1 1 0 1

乘数最低位为1,+X

0 0 1 1 0 1

0 0 0 1 1 0

1 1 0 1

1(丢)

右移部分积和乘数

+) 0 0 1 1 0 1

乘数最低位为1,+X

0 1 0 0 1 1

0 0 1 0 0 1

1 1 1 0

1(丢)

右移部分积和乘数

+) 0 0 0 0 0 0

乘数最低位为0,+0

0 0 1 0 0 1

0 0 0 1 0 0

1 1 1 1

0(丢)

右移部分积和乘数

+) 0 0 1 1 0 1

乘数最低位为1,+X

0 1 0 0 0 1

0 0 1 0 0 0

1 1 1 1

1(丢)

右移部分积和乘数

四、原码一位除的实现:一般用不恢复余数法(加减交替法)

部分积

低位部分积 附加位

操作说明

0 0 0 0 0 0

1 0 1 1

起始情况

+) 0 0 0 0 0 0

乘数最低位为1,+X

0 0 0 0 0 0

0 0 0 0 0 0

1 1 0 1

1(丢)

右移部分积和乘数

+) 1 1 0 0 1 1

乘数最低位为1,+X

0 1 0 0 1 1

0 0 1 0 0 1

1 1 1 0

1(丢)

右移部分积和乘数

+) 0 0 0 0 0 0

乘数最低位为0,+0

0 0 1 0 0 1

0 0 0 1 0 0

1 1 1 1

0(丢)

右移部分积和乘数

+) 0 0 1 1 0 1

乘数最低位为1,+X

0 1 0 0 0 1

0 0 1 0 0 0

1 1 1 1

1(丢)

右移部分积和乘数

§2.5 浮点运算与浮点运算器

一、浮点数的运算规则

1、浮点加减法的运算步骤

设两个浮点数 X=Mx※2Ex Y=My※2Ey

实现X±Y要用如下5步完成:

①对阶操作:小阶向大阶看齐

②进行尾数加减运算

③规格化处理:尾数进行运算的结果必须变成规格化的浮点数,对于双符号位的补码尾数来说,就必须是

001×××…×× 或110×××…××的形式

若不符合上述形式要进行左规或右规处理。

④舍入操作:在执行对阶或右规操作时常用“0”舍“1”入法将右移出去的尾数数值进行舍入,以确保精度。

⑤判结果的正确性:即检查阶码是否溢出

若阶码下溢(移码表示是00…0),要置结果为机器0;

若阶码上溢(超过了阶码表示的最大值)置溢出标志。

例题:假定X=0 .0110011*211,Y=0.1101101*2-10(此处的数均为二进制) ?? 计算X+Y;

解:[X]浮: 0 1 010 1100110

[Y]浮: 0 0 110 1101101

符号位 阶码 尾数

第一步:求阶差: │ΔE│=|1010-0110|=0100

第二步:对阶:Y的阶码小, Y的尾数右移4位

[Y]浮变为 0 1 010 0000110 1101暂时保存

第三步:尾数相加,采用双符号位的补码运算

00 1100110

+00 0000110

00 1101100

第四步规格化:满足规格化要求

第五步:舍入处理,采用0舍1入法处理

故最终运算结果的浮点数格式为: 0 1 010 1101101,

即X+Y=+0. 1101101*210

2、浮点乘除法的运算步骤

①阶码运算:阶码求和(乘法)或阶码求差(除法)

即 [Ex+Ey]移= [Ex]移+ [Ey]补

[Ex-Ey]移= [Ex]移+ [-Ey]补

②浮点数的尾数处理:浮点数中尾数乘除法运算结果要进行舍入处理

例题:X=0 .0110011*211,Y=0.1101101*2-10求X※Y

解:[X]浮: 0 1 010 1100110

[Y]浮: 0 0 110 1101101

第一步:阶码相加

[Ex+Ey]移=[Ex]移+[Ey]补=1 010+1 110=1 000

1 000为移码表示的0

第二步:原码尾数相乘的结果为:

0 10101101101110

第三步:规格化处理:已满足规格化要求,不需左规,尾数不变,阶码不变。

第四步:舍入处理:按舍入规则,加1进行修正

所以 X※Y= 0.1010111※2+000

chapter two

计算机内部,数是用二进制表示的。二进制数的编码方式有补码、原码、反码 和增码。二进制数的表示形式有定点表示(整数INTEGER和20到2-1之间的数)和浮点 表示两种。 无论什么数,它总是由符号和数值两部分组成。在计算机中数值和符号用某种 编码的形式表示。为明确起见,把原来的数值叫做真值,而把机器中对符号和数值 进行编码之后的数值叫做机器数。 1.原码 ▲n位二进制定点小数X=x0x1x2...xn-1的原码[X]原定义为: ┌X 当1>X>=0时 [X]原=┤ └1-X=1+│X│ 当0>=X>-1时 其特点有: (1)0的原码有两种,即0.0000...0和1.0000...0。 n个 n个 (2)数的表示范围[-(1-2-n+1),(1-2-n+1)] (3)最高位为符号位.若负数时符号位为1;正数则符号位为0. (4)作乘除运算时较为方便,但作加减运算时较为复杂. 例: 若X=0.0101101.则[X]原=0.0101101 若X=-0.1010010,则[X]原=1.1010010 ▲n位整数X的原码定义如下: ┌X 当2n-1>X>=0时 [X]原=┤ └2n-1-x=2n-1+│X│ 当0>=X>-2-n-1时 2.补码 ▲n位二进制定点小数X=x0x1x2...xn-1的补码[X]补定义为: ┌X 当1>X>=0时 [X]补=┤ └2+X=2-│X│ 当0>X>=-1时 其特点有: (1)0的补码有只有一种形式,即0.0000...0 n个 (2)数的表示范围[-1,(1-2-n+1)] (3)最高位为符号位.若负数时符号位为1;正数则符号位为0. (4)对于两个数X,Y,且X+Y不溢出,则有[X+Y]补=[X]补+[Y]补. (5)补码加法的溢出判别,若两数均为负数相加,则最高位进位是0为下溢;若 两数均为正数相加,则最高位是1为上溢;若一正数和一负数相加,则不会发生溢出. (6)作加减运算时较为方便,但作乘除运算时要比原码复杂. 例:若 X=-0.1000100, 则[X]补=10-0.1000100=1.0111100 若 X=0.1000001, 则[X]补=X=0.1000001 注:负数补码的求法:按位求反末位加1 如:求-0.1000100的补码

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值