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

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 还是 double,分别编码:阶码位数、尾数位数、偏置常数各不相同。要表示到足够的位数。 (4) 16 进制数后面要写 H 标识,二进制数后面要写 B 标识 参考答案:参考答案: (1)FFFF8000H 解:-215=-1000 0000 0000 0000B,负数符号位为 1,int 型整数表示为 32 位, 故机器数为 11 1000 0000 0000 0000=FFFF8000H (2)02。

2、0AH 解:522=10 0000 1010B,正数符号位为 0,short 型整数表示为 16 位, 故机器数为 0000 0010 0000 1010=020AH (3)0000FFFAH 解: 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=BF8CCCCCH (6)40250000 00000000H 解:10.5=1010.1B=1.0101B23(左规) , Double 型浮点数,阶码为 1023+3=100 0000 0010,整。

3、数部 1 为隐藏位,正数符号位为 0, 故机器数为 0 100 0000 0010 0101 0000=40250000 00000000H 10. 在 32 位计算机中运行一个 C 语言程序,在该程序中出现了一些变量,已知这些变量在某一时刻的机器数(用十六进制表示)如下,请写出它们对应的真值。 (1)int x:FFFF0006H (2)short y:DFFCH (3)unsigned 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 (2)-。

4、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=1100 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 0。

5、010 0100 1000 0 00B,因为是 double 型浮点数,所以按照IEEE 754 标准解析。符号位为 1,所以为负数;阶码为 100 0000 0010, ,减掉偏置常数 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 ( int x, int y) int t = x; x 2; return x+y; 本题要点:本题要点: 直接用 C 语言写的源代码和反编译后的代码形式上不一致,所以要从功能的角度分析,而不能只从字面看。 参考答案:参考答案: 答。

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

7、参参考答案:考答案: 解: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 位,阶码中最后一个 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 中每个字节在主存的存放位置。

8、。 本题要点:本题要点: (1) 正确区分大端、小端数据表示,注意字节顺序注意字节顺序。 (2) 将 x、y 和 i 根据其类型正确换算成相应的位串(机器数) ,尤其是浮点数,要会转换成二进制。注意:长度不同,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 111000 (40F0 0000H) (3)100=64+32+4=1100100B,正整数,直接转换,所以 i 在 32 位的机器内部表示的机器数为:0000 0000 0110 0100(0064H) 所以 x、y 和 i 在主存中的情况如下: (注。

9、意三个数的起始地址) 大端机 小端机 地址 内容 内容 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 和 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) 正确使用模运算 参考答案:参考答案: 表表 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。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值