新版汇编语言程序设计【课后习题答案】
第1章 汇编语言基础知识
〔习题1.1〕简述计算机系统的硬件组成及各部分作用。
  〔解答〕
      CPU:包括运算器、控制器和寄存器组。运算器执行所有的算术和逻辑运算;控制器负责把指指令逐条从存储器中取出,经译码分析后向机器发出各种控制命令,并正确完成程序所要求的功能;寄存器组为处理单元提供所需要的数据。
存储器:是计算机的记忆部件,它用来存放程序以及程序中所涉及的数据。
外部设备:实现人机交换和机间的通信。
〔习题1.2〕明确下列概念或符号:
主存和辅存,RAM和ROM,存储器地址和I/O端口,KB、MB、GB和TB
〔解答〕
主存又称内存是主存储器的简称,主存储器存放当前正在执行的程序和使用的数据,CPU可以直接存取,它由半导体存储器芯片构成其成本高、容量小、但速度快。辅存是辅助存储器的简称,辅存可用来长期保存大量程序和数据,CPU需要通过I/O接口访问,它由磁盘或光盘构成,其成本低、容量大,但速度慢。
RAM是随机存取存储器的英语简写,由于CPU可以从RAM读信息,也可以向RAM写入信息,所以RAM也被称为读写存储器,RAM型半导体存储器可以按地址随机读写,但这类存储器在断电后不能保存信息;而ROM中的信息只能被读出,不能被修改,ROM型半导体通常只能被读出,但这类存储器断电后能保存信息。
存储器由大量存储单元组成。为了区别每个单元,我们将它们编号,于是,每个存储单元就有了一个存储地址,I/O接口是由一组寄存器组成,为了区别它们,各个寄存器进行了编号,形成I/O地址,通常称做I/O端口。
KB是千字节、MB是兆字节、GB是吉字节和TB是太字节,它们都是表示存储器存储单元的单位。
〔习题1.3〕什么是汇编语言源程序、汇编程序、目标程序?
〔解答〕
用汇编语言书写的程序就称为汇编语言源程序;完成汇编工作的程序就是汇编程序;由汇编程序编译通过的程序就是目标程序。
〔习题1.4〕汇编语言与高级语言相比有什么优缺点?
〔解答〕
汇编语言与高级语言相比的优点:由于汇编语言本质就是机器语言,它可以直接地、有效地控制计算机硬件,因而容易产生运行速度快,指令序列短小的高效目标程序,可以直接控制计算机硬件部件,可以编写在“时间”和“空间”两方面最有效的程序。
汇编语言与高级语言相比的缺点:由于与处理器密切相关导致通用性差、可移植性差,汇编语言功能有限,又涉及寄存器、主存单元等硬件细节,编写汇编语言比较繁琐,调试起来也比较困难,编译程序产生的目标程序往往比较庞大、程序难以优化,运行速度慢。
〔习题1.5〕将下列十六进制数转换为二进制和十进制表示
(1)FFH            (2)0H          (3)5EH                  (4)EFH
(5)2EH            (6)10H        (7)1FH                  (8)ABH
〔解答〕
(1)FFH                  11111111B                                255D 
(2)0H                    0B                                        0D 
(3)5EH                1011110B                                    94D
(4)EFH              11101111B                                    239D
(5)2EH                  101110B                                    46D
(6)10H                    10000B                                    16D
(7)1FH                    11111B                                    31D
(8)ABH                  10101011B                                171D
〔习题1.6〕
将下列十进制数转换为BCD码表示
(1)12                (2)24                (3)68                (4)127
(5)128              (6)255              (7)1234            (8)2458
〔解答〕
(1)12                00010010     
(2)24                00100100     
(3)68                01101000             
(4)127              000100100111
(5)128              000100101000         
(6)255              001001010101
(7)1234            0001001000110100
(8)2458            0010010001011000
〔习题1.7〕
将下列BCD码转换为十进制数
(1)10010001      (2)10001001      (3)00110110      (4)10010000
(5)00001000    (6)10010111    (7)10000001    (8)00000010
〔解答〕
(1)91 
(2)89 
(3)36             
(4)90
(5)08             
(6)97
(7)81             
(8)02
〔习题1.8〕将下列十进制数分别用8位二进制数的原码、反码和补码表示
(1)0                  (2)-127            (3)127              (4)-57
(5)126              (6)-126            (7)-128            (8)68
〔解答〕
(1)0  +0  00000000  00000000  00000000         
              -0  10000000  11111111  00000000
(2)-127    11111111  10000000  10000001
(3)127    01111111  01111111  01111111         
(4)-57    10101111    11010000  11010001
(5)126    01111110    01111110  01111110
(6)-126    11111110    10000001  10000010
(7)-128                                          10000000
(8)68      01000100    01000100  01000100
〔习题1.9〕完成下列二进制数的运算
basic语言解释程序属于什么
(1)1011+1001  (2)1011-1001  (3)1011×1001  (4)10111000÷1001
(5)1011 ∧1001  (6)1011 ∨1001 (7)~1011          (8)1011 ? 1001
〔解答〕
(1)1011+1001=10100   
(2)1011-1001=0010     
(3)1011×1001=1100011 
(4)10111000÷1001=10100,余数 1000
(5)1011 ∧ 1001=1001     
(6)1011 ∨1001=1011     
(7)~1011=0100     
(8) 1011?1001=0010(?代表异或)
〔习题1.10〕数码0~9、大写字母A~Z、小写字母a~z对应的ASCII码分别是多少?ASCII码为0dh、0ah对应的是什么字符?
〔解答〕
数码0~9:30H~39H
大写字母A~Z:41H~5AH
小写字母a~z:61H~7AH
ASCII码为0dh、0ah分别对应回车和换行控制字符。
〔习题1.11〕计算机中有一个“01100001”编码,如果把它认为是无符号数,它是十进制什么数?如果认为它是BCD码,则表示什么数?又如果它是某个ASCII码,则代表哪个字符?
〔解答〕
十进制无符号数:01100001B=61H=97
BCD码:61
ASCII码:a
〔习题1.12〕简述Intel 80x86系列微处理器在指令集方面的发展。
〔解答〕
1978年Intel,正式推出了16位8086CPU,1979年Intel推出了准16位微处理器8088,随后,Intel推出了80186/80188,80186/80188指令系统比8086指令系统新增了若干条实用的指令,涉及堆栈操作、移位指令、过程指令和边界检测及乘法指令,1982年Intel推出80286 CPU, 80286指令系统包括全部80186指令及新增的保护指令15条,其中有些保护方式在实方式下也可以使用,1985年,Intel80x86推出微处理器地进入第三代80386 CPU, 80386指令系统在兼容原来16位指令系统的基础上,全面升级为32位,还新增了有关位操作、条件设置指令以及控制、调试和测试寄存器的传送指令等,1989年,Intel推出了80486CPU,80486将浮点处理单元FPU集成进来,还采用了精简指令集计算机技术RISC和指令流水线方式,还新增了用于多处理器和内部Cache操作的6条指令,1993年Intel制成了俗称586的微处理器,取名Pentium。Pentium仍为32位结构,地址总线为32位,对常用的简单指令用硬件实现,重新设计指令的微代码等,Pentium新增了一条8字节比较交换指令和一条处理器识别指令,以及4条系统专用指令,1996年推出了MMX Pentium,新增了57条多媒休指令,1995年Intel推出Pentium Pro新增了3条指令,1999年推出了PentiumⅢ新增了70条SSE指令,2000年推出的Pentium4新增了76条SSE2指令

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。