计算机系统基础第二章习题参考答案-2018资料

上传人:w****i 文档编号:107673534 上传时间:2019-10-20 格式:PDF 页数:15 大小:799.58KB
返回 下载 相关 举报
计算机系统基础第二章习题参考答案-2018资料_第1页
第1页 / 共15页
计算机系统基础第二章习题参考答案-2018资料_第2页
第2页 / 共15页
计算机系统基础第二章习题参考答案-2018资料_第3页
第3页 / 共15页
计算机系统基础第二章习题参考答案-2018资料_第4页
第4页 / 共15页
计算机系统基础第二章习题参考答案-2018资料_第5页
第5页 / 共15页
点击查看更多>>
资源描述

《计算机系统基础第二章习题参考答案-2018资料》由会员分享,可在线阅读,更多相关《计算机系统基础第二章习题参考答案-2018资料(15页珍藏版)》请在金锄头文库上搜索。

1、第第 二二 章章 习习 题题 答答 案案 9 在 32 位计算机中运行一个 C 语言程序,在该程序中出现了以下变量的初值,请写出它们对应的机器 数(用十六进制表示) 。 (1)int x=-32768 (2)short y=522 (3)unsigned z=65530 (4)char c= (5)float a=-1.1 (6)double b=10.5 本题要点:本题要点: (1) 数据要根据其类型要表示到足够的位数,如题(3) ,要写成 0000FFFA,而不是 FFFA (2) 因为求机器数,所以负数要用补码表示 (3) 浮点数要用 IEEE 754 标准编码,要注意是 float 还

2、是 double,分别编码:阶码位数、尾数位数、 偏置常数各不相同。要表示到足够的位数。 (4) 16 进制数后面要写 H 标识,二进制数后面要写 B 标识 参考答案:参考答案: (1)FFFF8000H 解:-215=-1000 0000 0000 0000B,负数符号位为 1,int 型整数表示为 32 位, 故机器数为 11 1000 0000 0000 0000=FFFF8000H (2)020AH 解:522=10 0000 1010B,正数符号位为 0,short 型整数表示为 16 位, 故机器数为 0000 0010 0000 1010=020AH (3)0000FFFAH 解

3、: 65530=216-1-5=1111 1111 1111 1010B, unsigned 型整数表示为 32 位, 无符号位 (高位补 0) , 故机器数为 0000FFFAH (4)40H 解:的 ASCII 码是 40H,char 型表示为 8 位 (5)BF8CCCCCH 解:-1.1=-1.00011 0011B=-1.000 1100 1100 1100 1100 1100B, float 型浮点数,阶码为 127+0=01111111(8 位) ,整数部 1 为隐藏位,负数符号位为 1, 故机器数为 1 01111111 000 1100 1100 1100 1100 1100

4、=BF8CCCCCH (6)40250000 00000000H 解:10.5=1010.1B=1.0101B23(左规) , Double 型浮点数,阶码为 1023+3=100 0000 0010,整数部 1 为隐藏位,正数符号位为 0, 故机器数为 0 100 0000 0010 0101 0000=40250000 00000000H 10. 在 32 位计算机中运行一个 C 语言程序,在该程序中出现了一些变量,已知这些变量在某一时刻的机 器数(用十六进制表示)如下,请写出它们对应的真值。 (1)int x:FFFF0006H (2)short y:DFFCH (3)unsigned

5、z:FFFFFFFAH (4)char c:2AH 5)float a:C4480000H (6)double b:C024800000000000H 本题要点本题要点 (1) 正确换算,结果最好表示成 10 进制 (2) 注意数据类型,准确区分有符号数和无符号数,有符号数最高位为 1 时为负数 (3) 正确解析浮点数 参考答案:参考答案: (1)-65530 解:FFFF0006H=11 0000 0000 0000 0110B,最高位为 1,所以为负数,int 型整数,所以真值 为其余为取反加 1,故 x= -1111 1111 1111 1010B= -(65535-5)=-65530

6、(2)-8196 解:DFFCH=1101 1111 1111 1100B=-010 0000 0000 0100B,最高位为 1,所以为负数,short 型整 数,所以真值为其余为取反加 1,故 y=-(8192+4)=-8196 (3)4294967290(或 232-6) 解:FFFFFFFAH=11 1010B,最高位虽然为 1,但为 unsigned 型整数,所以解析为正整数,直 接展开换算,故 z=232-6=4294967290 (4)字符* 解:2AH=0010 1010B,故 c 的值是 42,且 c 表示字符,故 c 为字符* (5)-800 解:C4480000H=110

7、0 0100 0100 1000 00B,因为是 float 型浮点数数据,所以按照 IEEE 754 标 准解析。符号位为 1,所以为负数;阶码为 10001000,减掉偏置常数 127 后有:阶为 136-127=9;尾数考 虑隐藏位为:-1.1001B,故 a=-1.1001B29= -11 0010 0000B= -800 (6)-10.25 解:C024800000000000H=1100 0000 0010 0100 1000 0 00B,因为是 double 型浮点数,所以按照 IEEE 754 标准解析。符号位为 1,所以为负数;阶码为 100 0000 0010, ,减掉偏置

8、常数 1023 后有:阶为 1026-1023=3;尾数考虑隐藏位为 1.01001B,故 b=-1.01001B23= 1010.01B=-10.25 17. 以下是一个由反汇编器生成的一段针对某个小端方式处理器的机器级代码表示文本,其中,最左边 是指令所在的存储单元地址,冒号后面是指令的机器码,最右边是指令的汇编语言表示,即汇编指 令。已知反汇编输出中的机器数都采用补码表示,请给出指令代码中划线部分表示的机器数对应的 真值。 80483d2: 81 ec b8 01 00 00 sub result = x*M + y/N; return result; int optarith ( in

9、t x, int y) int t = x; x 2; return x+y; 本题要点:本题要点: 直接用 C 语言写的源代码和反编译后的代码形式上不一致,所以要从功能的角度分析,而不能只从 字面看。 参考答案:参考答案: 答案:M=15,N=4 解: (1)对照源代码语句中的“x*M”和反编译代码中的“int t = x; x 2;” ,可以分析出, “y2”实现了 y 除以 4 的功能,因此 N 是 4。 而比较迷惑的是第一句“if ( y 2= 1(-1 的补码表示是 FFFFFFFFH,移 位后还是 FFFFFFFFH,其值还是-1) ,而1/4=0(数学定义) ,所以两者不等,不符

10、合数学定义;故做上 述调整,调整后 1+3=2,22=0,两者相等,正确。 24设一个变量的值为 4098,要求分别用 32 位补码整数和 IEEE 754 单精度浮点格式表示该变量(结果 用十六进制形式表示) ,并说明哪段二进制位序列在两种表示中完全相同,为什么会相同? 本题要点:本题要点: (1) 按照 32 位补码整数和 IEEE 754 单精度浮点格式准确表示 4098 的值, 尤其是浮点数位串不要 搞错了。 (2) 找出位串相同的部分,为什么相同主要是 4098 数比较小,在 32 位补码整数(且为正数)和 23 位浮点尾数部分都能精确表示(没有舍入) ,所以对应相等(除了浮点数最高

11、位,因为浮 点数有 1 个隐藏位) 。 参参考答案:考答案: 解:4098 = +1 0000 0000 0010B(整数) = +1. 0000 0000 001 212(规格化浮点数) (1)32 位 2-补码形式为:0000 0000 0000 0000 0001 0000 0000 0010(即(即 00001002H) (2)IEEE754 单精度格式为:0 10001011 0000 0000 0010 0000 0000 000 (即 45801000H) 对照(1)和(2)的位串,粗体部分的 12 位位串为相同部分。 注:浮点数中粗体部分为除隐藏位外的有效数字,只考虑这 12

12、位,阶码中最后一个 1 不考虑。 28假定在一个程序中定义了变量 x、y 和 i,其中,x 和 y 是 float 型变量(用 IEEE754 单精度浮点数表 示) ,i 是 16 位 short 型变量(用补码表示) 。程序执行到某一时刻,x= 0.125、y=7.5、i=100,它们 都被写到了主存(按字节编址) ,其地址分别是 100,108 和 112。请分别画出在大端机器和小端机器 上变量 x、y 和 i 中每个字节在主存的存放位置。 本题要点:本题要点: (1) 正确区分大端、小端数据表示,注意字节顺序注意字节顺序。 (2) 将 x、y 和 i 根据其类型正确换算成相应的位串(机器

13、数) ,尤其是浮点数,要会转换成二进 制。注意:长度不同,x 和 y 是 32 位,i 是 16 位。 参考答案:参考答案: 解: 首先,将 x、y 和 i 换算成正确的机器数 (1)0.125 = 0.001B = 1.0 2-3,负浮点数,符号位为 1, 阶码为-3(加偏置常数 127 后为 124) ,尾数为.0,所以,x 在机器内部的机器数为:1 01111100 000 (BE00 0000H) (2)7.5= +111.1B= +1.111 22,正浮点数,阶码为 2(加偏置常数 127 后为 129) ,尾数 为.111,所以,y 在机器内部的机器数为:0 10000001 11

14、1000 (40F0 0000H) (3)100=64+32+4=1100100B,正整数,直接转换,所以 i 在 32 位的机器内部表示的机 器数为:0000 0000 0110 0100(0064H) 所以 x、y 和 i 在主存中的情况如下: (注意三个数的起始地址) 大端机 小端机 地址 内容 内容 100 BEH 00H 101 00H 00H 102 00H 00H 103 00H BEH 108 40H 00H 109 F0H 00H 110 00H F0H 111 00H 40H 112 00H 64H 113 64H 00H 29. 对于图 2.6,假设 n=8,机器数 X

15、和 Y 的真值分别是 x 和 y。请按照图 2.6 的功能填写表 2.17,并给 出对每个结果的解释。要求机器数用十六进制形式填写,真值用十进制形式填写。 表表 2.17 题题 29 用表用表 表示 X x Y Y X+Y x+y OF SF CF X-Y x-y OF SF CF 无符号 0xB0 0x8C 带符号 0xB0 0x8C 无符号 0x7E 0x5D 带符号 0x7E 0x5D 本题要点:本题要点: (1) 注意位长只有 8 位,所以无符号数超过 255 或有符号数小于-128 或大于+127 将进位和溢出 (2) 正确计算有符号数和无符号数的值 (3) 正确使用模运算 参考答案

16、:参考答案: 表表 2.17 题题 29 用表用表 表示 X x Y Y X+Y x+y OF SF CF X-Y x-y OF SF CF 无符号 0xB0 176 0x8C 140 0x3C 60 1 0 1 0x24 36 0 0 0 带符号 0xB0 -80 0x8C -116 0x3C 60 1 0 1 0x24 36 0 0 0 无符号 0x7E 126 0x5D 93 0xDB 219 1 1 0 0x21 33 0 0 0 带符号 0x7E 126 0x5D 93 0xDB -37 1 1 0 0x21 33 0 0 0 (1)无符号整数 176+140=316,无法用 8 位无符号数表示,即结果应有进位,CF 应为 1。减 256,得 60,验证正确。 (2)无符号整数 176-140=36,可用 8 位

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 办公文档 > 其它办公文档

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号