《第二章习题-ddg》由会员分享,可在线阅读,更多相关《第二章习题-ddg(7页珍藏版)》请在金锄头文库上搜索。
1、第 二 章 习 题 答 案1 给出以下概念的解释说明。真值机器数数值数据 非数值数据无符号整数带符号整数定点数原码补码 变形补码溢出浮点数尾数阶阶码 移码阶码下溢阶码上溢规格化数左规右规 非规格化数机器零非数(NaN)BCD码逻辑数 ASCII码 汉字输入码汉字内码机器字长大端方式小端方式 最高有效位 最高有效字节(MSB)最低有效位最低有效字节(LSB) 掩码 算术移位逻辑移位0扩展符号扩展零标志ZF溢出标志OF 符号标志SF进位/借位标志CF2 简单回答下列问题。(1)为什么计算机内部采用二进制表示信息?既然计算机内部所有信息都用二进制表示,为什么还要用到十六进制或八进制数?(2)常用的定
2、点数编码方式有哪几种? 通常它们各自用来表示什么?(3)为什么现代计算机中大多用补码表示带符号整数?(4)在浮点数的基数和总位数一定的情况下,浮点数的表示范围和精度分别由什么决定?两者如何相互制约?(5)为什么要对浮点数进行规格化?有哪两种规格化操作?(6)为什么有些计算机中除了用二进制外还用BCD码来表示数值数据?(7)为什么计算机处理汉字时会涉及到不同的编码(如,输入码、内码、字模码)?说明这些编码中哪些用二进制编码,哪些不用二进制编码,为什么?3实现下列各数的转换。(1) (25.8125)10= (?)2= (?) 8= (?) 16(2) (101101.011)2 = (?)10=
3、 (?) 8= (?) 16= (?) 8421(3) (0101 1001 0110.0011)8421 = (?)10= (?) 2= (?) 16(4) (4E.C)16 = (?)10= (?) 24 假定机器数为8位(1位符号,7位数值),写出下列各二进制数的原码表示。+0.1001,0.1001,+1.0,1.0,+0.010100,0.010100,+0,05 假定机器数为8位(1位符号,7位数值),写出下列各二进制数的补码和移码表示。+1001,1001,+1,1,+10100,10100,+0,06 已知 x补,求x(1)x补=11100111 (2)x补=10000000(
4、3)x补=01010010 (4)x补=110100117 某32位字长的机器中带符号整数用补码表示,浮点数用IEEE 754标准表示,寄存器R1和R2的内容分别为R1:0000108BH,R2:8080108BH。不同指令对寄存器进行不同的操作,因而不同指令执行时寄存器内容对应的真值不同。假定执行下列运算指令时,操作数为寄存器R1和R2的内容,则R1和R2中操作数的真值分别为多少?(1) 无符号整数加法指令(2) 带符号整数乘法指令(3) 单精度浮点数减法指令8 假定机器M的字长为32位,用补码表示带符号整数。表2.12中第一列给出了在机器M上执行的C语言程序中的关系表达式,请参照已有的表栏
5、内容完成表中后三栏内容的填写。表2.12 题8用表关系表达式运算类型结果说明0 = 0U1 01 2147483647 12147483647U 2147483647 12147483647 (int) 2147483648U1 2(unsigned) 1 2无符号整数有符号整数01 111B (2321) 000B(0)0111B (2311) 1000B (231)9 在32位计算机中运行一个C语言程序,在该程序中出现了以下变量的初值,请写出它们对应的机器数(用十六进制表示)。(1)int x=-32768 (2)short y=522(3)unsigned z=65530(4)char
6、c=(5)float a=-1.1(6)double b=10.510. 在32位计算机中运行一个C语言程序,在该程序中出现了一些变量,已知这些变量在某一时刻的机器数(用十六进制表示)如下,请写出它们对应的真值。(1)int x:FFFF0006H (2)short y:DFFCH(3)unsigned z:FFFFFFFAH(4)char c:2AH5)float a:C4480000H(6)double b:C024800000000000H11. 以下给出的是一些字符串变量在内存中存放的字符串机器码,请根据ASCII码定义写出对应的字符串。指出代码0AH和00H对应的字符的含义。(1)c
7、har *mystring1:68H 65H 6CH 6CH 6FH 2CH 77H 6FH 72H 6CH 64H 0AH 00H (2)char *mystring2:77H 65H 20H 61H 72H 65H 20H 68H 61H 70H 70H 79H 21H 00H12. 以下给出的是一些字符串变量的初值,请写出对应的机器码。(1)char *mystring1=./myfile (2)char *mystring2=OK, good!13. 已知C语言中的按位异或运算(“XOR”)用符号“”表示。对于任意一个位序列a,aa=0,C语言程序可以利用这个特性来实现两个数值交换的功
8、能。以下是一个实现该功能的C语言函数: 1void xor_swap(int *x, int *y) 2 3*y=*x *y;/* 第一步 */4*x=*x *y;/* 第二步 */5*y=*x *y;/* 第三步 */ 6 假定执行该函数时*x和*y的初始值分别为a和b,即*x=a且*y=b,请给出每一步执行结束后,x和y各自指向的内存单元中的内容分别是什么?14. 假定某个实现数组元素倒置的函数reverse_array调用了第13题中给出的xor_swap函数: 1void reverse_array(int a, int len)2 3int left, right=len-1;4fo
9、r (left=0; left 0;4 已知C语言标准库函数strlen原型声明为“size_t strlen(const char *s);”,其中,size_t被定义为unsigned int类型。请问:函数compare_str_len在什么情况下返回的结果不正确?为什么?为使函数正确返回结果应如何修改代码?19考虑以下C语言程序代码:1int func1(unsigned word)23return (int) ( word 24);45int func2(unsigned word)67return ( (int) word 24;8假设在一个32位机器上执行这些函数,该机器使用二进制补码表示带符号整数。无符号数采用逻辑移位,带符号整数采用算术移位。请填写表2.14,并说明函数func1和func2的功能。表2.14 题19用表wfunc1(w)func2(w)机器数值机器数值机器数值