资源描述
微型计算机原理及应用自学指导书前 言微型计算机原理及应用自学指导书作为读者在学习本课程时的辅导。编排时与大纲的各章对应,共分九章:概述, 8086CPU结构,8086的指令系统,8086CPU的基本时序,半导体存储器与CPU的接口,输入与输出,中断技术,总线,接口技术应用。这一部分概括了各章的主要问题,并从便于自学的角度进行讨论。目的在于帮助读者澄清某些模糊概念,对微型计算机原理及应用的基本概念、原理、应用加深理解。第一章 概 述一、内容概述11 计算机和微型计算机的发展概况从1946年第一台计算机ENIAC问世以来,计算机的发展已经历了四代:即以电子管为主要器件的第一代;以晶体管为主要器件的第二代;以中小规模集成电路为主要器件的第三代和应用大规模、超大规模集成电路的第四代电子计算机。第五代智能计算机和第六代神经元计算机也正在研制之中。12 微型计算机的特点与应用范围微处理器具有成本低、灵活性强、可靠性高、开发时间短以及速度快等特点,因此,微型计算机具有广泛的应用范围,可概括为数值计算、数据处理和实时控制三个方面。13 微型计算机系统的基本组成微型计算机系统由两大部分组成,即硬件和软件。计算机系统的硬件主要包括微型计算机、外围设备、控制面板和电源等。若把微处理器、存储器、输入输出接口通过系统总线连接起来,就组成了微型计算机。软件是各种程序的总称,由系统软件和用户(应用)软件组成,其中系统软件包括操作系统、文件管理程序、IO驱动程序、文本编辑程序等,用户软件包括各种用户程序和用户程序库。14 微型计算机的工作原理当今世界上有数以千万计的计算机,尽管系列不同,型号各异,但就其工作原理而论,绝大多数都是基于由匈牙利籍数学家冯诺依曼提出的“存储程序控制原理”。程序存储是指描述信息处理的程序必须以目标程序的形式连同原始数据保存在内存储器中,这是计算机能自动连续工作曲前提。程序控制是指计算机根据预先编好并已存于内存的程序自动地、连续地控制全机工作,直到获得预期的结果的过程。15 典型的微处理器结构微处理器是一种利用大规模集成电路工艺制作的器件。它能进行算术、逻辑和控制操作。典型的微处理器内部结构主要由寄存器阵列、累加和算术逻辑单元及控制单元组成。16 十进制数运算日常生活中实际应用的原始数据大多是十进制数,十进制数不能直接送入计算机中参加运算,必须用二进制数为它编码,使其成为二一十进制码或称BCD码后方能送入计算机。送入计算机的BCD码或经十一二转换程序变为二进制数后参加运算,或直接由计算机进行二一十进制运算(即BCD码运算)。常见的BCD码有8421码、2421码和余3码等。用二进制指令进行十进制运算时,可用DAA接在BCD数的加法或减法指令的后面,自动按照规则进行“加6修正”或“减6修正”,以调整累加器的内容为正确的BCD形式。值得注意的是, DAA指令不能将任何一个二进制数都转换为BCD数。二、教学要求通过对电子计算机及微型计算发展史的了解,将使读者对这门新兴学科产生兴趣,从而增强学习该课程的自觉性。与一般计算机相比,微型计算机有自己的特点。因此,要着重理解微处理器的结构、组成、功能与外部连线。对微型计算机及微型计算机系统的定义,对8086微处理器的工作原理和十进制数运算方法必须要有所了解,对一些基本术语要学会掌握。三、重点难点微型计算机系统的基本组成及其工作原理;典型微处理器的结构和十进制数的运算方法。四、习题1、计算机分那几类?各有什么特点?答:传统上分为三类:大型主机、小型机、微型机。大型主机一般为高性能的并行处理系统, 存储容量大,事物处理能力强,可为众多用户提供服务。小型机具有一定的数据处理能力,提供一定用户规模的信息服务,作为部门的信息服务中心。微型机一般指在办公室或家庭的桌面或可移动的计算系统,体积小、价格低、具有工业化标准体系结构,兼容性好。2、简述微处理器、微计算机及微计算机系统三个术语的内涵。答:微处理器是微计算机系统的核心硬件部件,对系统的性能起决定性的影响。微计算机包括微处理器、存储器、I/O接口电路及系统总线。微计算机系统是在微计算机的基础上配上相应的外部设备和各种软件,形成一个完整的、独立的信息处理系统。3、80X86微处理器有几代?各代的名称是什么?答:从体系结构上可分为3代: 8080/8085:8位机。 8086/8088/80286:16位机。 80386/80486:32位机。第二章 8086CPU结构一、内容概述21 存储器8086CPU无论在什么样的工作模式下,都可以寻址1M字节的存储空间。在1M的存储器空间(00000HFFFFFH)中,各段的起始地址存放在各段寄存器中。16位地址的偏移量由EU产生,从而CPU可以寻址到该段中的每一个存储单元。(一) 逻辑地址与实际地址的关系所谓逻辑地址是指在程序中出现的地址值,如段寄存器中存放的地址值以及地址的偏移量,这两个地址值简单相加不能形成存储器的实际地址,而是要将段寄存器中存放的地址值左移四位以后,与偏移量相加,这才能得到存储器的实际地址。(二) 存储器分段方法:参阅周细等编微型计算机极其应用第二版正文。(三) 8086CPU与外部存储器连接在8086的存储器空间中,信息是按字节为单位存放的。在组织8086的存储器时,1M字节的存储空间被分成两个存储库(BANK),其中一个库与CPU数据总线的低字节D7Do相连,称之为低字节库;另一个库则与数据总线的高字节D15D8相连,称为高字节库。8086CPU为了实现对这两个库的寻址和控制,把地址线A19A1(该信号应是锁存后的输出)同时连接到低位库和高位库上,地址线A0不参加直接寻址,而是作为低位库的选择信号,接到低位库的端上。当A00时,选中低位库,使低位库所有地址的A0均为0(即为偶地址),而使高位库所有地址的A0均为1。高位库的选择信号由CPU的信号提供,A0与一起对存储库进行选择。22 8086微处理器的结构(一)概述8086共有95条基本指令,其中相当一部分指令的长度只有8位,在少数几位16位的指令中,只有前8位是操作码,另外8位则是数据的偏移量。由于8086是8080和8085指令系统的扩充型,因此8080和8085的指令码很容易转换成8086的指令码。8086有24种寻址方式,大体和8080相同。但是,由于8086的ALU是16位,因此大大增加了8086的寻址能力。(二) 8086的内部结构8086CPU由两个独立的工作单元组成,即执行单元EU和总线接口单元BIU。EU只负责执行指令,而BIU则负责从存储器或外部设备中读取操作码和操作数,并将结果写入指令所指出的地址中,以完成所有的总线操作。这两个单元处于并行工作状态,可以同时进行存取和执行指令的操作。这样就可以充分利用各部分电路和总线,提高8086执行指令的速度。BIU中有一个能存放6个字节的指令队列,BIU将预先取来的指令存放在这个队列中, EU要执行的指令一般从这个队列中取得。在不发生程序转移的情况下,BIU已经将要执行的指令提前取来存放在这个指令队列中了。23 堆栈堆栈有时也称为“下推表”或“后进先出队列”。8086使用堆栈是在存储器中执行的,它的位置由堆栈寄存器SS和堆栈指示器SP规定。SS给出当前堆栈的基址,SP给出了当前堆栈的钱顶TOS(TOP OF THE STACK),也就是SP给出了从堆栈段的基址到栈顶的补偿值。在一个系统中,一个堆钱的深度是不受限制的,但是当前使用的堆栈最长为64K字节,也就是一个段的长度。另外,堆栈的基址(SS)并不是堆栈的“栈底”。8086规定堆栈字为16位,不论是从堆栈中取出一个数,还是向堆栈中压入一个数,这个数都必须是一个16位的字,也就是说堆栈的操作都是字操作。24 8086CPU引脚(线)功能8086CPU芯片是一块具有40个引脚的集成电路块。为了节省引脚,许多引脚都具有双重定义,即具有复用功能。有些引脚根据时序的不同,其功能就有所区别。在ADoAD15这16条引脚上,CPU有时送地址信号,有时送数据信号。而有些引脚是因CPU的工作模式 (最小最大模式)不同而具有不同的功能的。25 8086基本系统概念(一) 8086总线周期概念8086是通过它的系统总线与外部逻辑打交道的。8086通过执行“总线周期”来传送数据或者取指令。(二) 8086地址和数据总线概念因为大多数与8086接口的存储器设备和外围设备在整个总线周期期间需要有稳定的地址,因此在T1期间,在多路转换地址数据总线上出现的地址应该锁存起来。锁存的地址用来选择所需的外围设备或存储单元。为了对地址数据总线进行分路转换,8086提供了一个允许地址锁存信号(ALE),利用它可以把地址放入到8282或8283的8位双稳态锁存器中去。26 最小方式在最小方式中,8086的MN引线接到VCC电源上。最小方式可以用在单板或双板的单CPU系统中。在最小方式中,8086的存储器空间地址为1M字节。输入输出空间为64K字节。数据总线为16位。8086直接提供总线控制信号(DT,ALE,M/,)。单个CPU抢占总线机能是通过HOLD和HLDA信号“使能”的。这种机能与现有的DMA控制器相匹配。27 最大方式在最大方式中,MN引线接地。最大方式用在多处理机和协处理机结构中。在最大方式中,有一个总线控制器。它接收从8086来的控制信号并将其作为输入。8288对这些输入进行译码,产生控制输出信号。其一些8086的控制信号也有一定的修改,以便为外面逻辑提供更多的信息。二、教学基本要求80X86微处理器是典型的符合一般结构的微处理器,选择该微处理器作为典型机进行教学,有助于理论联系实际,也有助于今后的实际工作。因此掌握80X86微处理器的结构、组成、工作原理、各引脚的功能以及其内部操作过程,掌握微型机系统存储器、堆栈的结构特点和8086基本系统的概念,对后面各章的学习十分重要。三、重点难点存储器的结构及其实际地址的产生;8086CPU的结构和其总线结构及8086的堆栈结构;8086基本系统概念及其最小方式。四、习题1、8086是多少位的微处理器?为什么?答:8086是16位的微处理器,其内部数据通路为16位,对外的数据总线也是16位。2、EU与BIU各自的功能是什么?如何协同工作?答:EU是执行部件,主要的功能是执行指令。BIU是总线接口部件,与片外存储器及I/O接口电路传输数据。EU经过BIU进行片外操作数的访问,BIU为EU提供将要执行的指令。EU与BIU可分别独立工作,当EU不需BIU提供服务时,BIU可进行填充指令队列的操作。3、8086/8088与其前一代微处理器8085相比,内部操作有什么改进?答:8085为8位机,在执行指令过程中,取指令与执行执令都是串行的。8086/8088由于内部有EU和BIU两个功能部件,可重叠操作,提高了处理器的性能。4、8086/8088微处理器内部有那些寄存器,它们的主要作用是什么?答:执行部件有8个16位寄存器,AX、BX、CX、DX、SP、BP、DI、SI。AX、BX、CX、DX一般作为通用数据寄存器。SP为堆栈指针存器,BP、DI、SI在间接寻址时作为地址寄存器或变址寄存器。总线接口部件设有段寄存器CS、DS、SS、ES和指令指针寄存器IP。段寄存器存放段地址,与偏移地址共同形成存储器的物理地址。IP的内容为下一条将要执行指令的偏移地址,与CS共同形成下一条指令的物理地址。5、8086对存储器的管理为什么采用分段的办法?答:8086是一个16位的结构,采用分段管理办法可形成超过16位的存储器物理地址,扩大对存储器的寻址范围 (1MB,20位地址)。若不用分段方法,16位地址只能寻址64KB空间。6、在8086中,逻辑地址、偏移地址、物理地址分别指的是什么?具体说明。答:逻辑地址是在程序中对存储器地址的一种表示方法,由段地址和段内偏移地址两部分组成,如1234H:0088H。偏移地址是指段内某个存储单元相对该段首地址的差值,是一个16位的二进制代码。物理地址是8086芯片引线送出的20位地址码,用来指出一个特定的存储单元。7、给定一个存放数据的内存单元的偏移地址是20C0H,(DS)=0C00EH,求出该内存单元的物理地址。答:物理地址:320F8H。8、8086/8088为什么采用地址/数据引线复用技术?答:考虑到芯片成本,8086/8088采用40条引线的封装结构。40条引线引出8086/8088的所有信号是不够用的,采用地址/数据线复用引线方法可以解决这一矛盾,从逻辑角度,地址与数据信号不会同时出现,二者可以分时复用同一组引线。9、8086与8088的主要区别是什么?答:8086有16条数据信号引线,8088只有8条;8086片内指令预取缓冲器深度为6字节,8088只有4字节。10、怎样确定8086的最大或最小工作模式?最大、最小模式产生控制信号的方法有何不同答:引线MN/MX#的逻辑状态决定8086的工作模式,MN/MX#引线接高电平,8086被设定为最小模式,MN/MX#引线接低电平,8086被设定为最大模式。最小模式下的控制信号由相关引线直接提供;最大模式下控制信号由8288专用芯片译码后提供,8288的输入为8086的S2#S0#三条状态信号引线提供。11、8086被复位以后,有关寄存器的状态是什么?微处理器从何处开始执行程序?答:标志寄存器、IP、DS、SS、ES和指令队列置0,CS置全1。处理器从FFFFOH存储单元取指令并开始执行。12、8086基本总线周期是如何组成的?各状态中完成什么基本操作?答:基本总线周期由4个时钟(CLK)周期组成,按时间顺序定义为T1、T2、T3、T4。在T1期间8086发出访问目的地的地址信号和地址锁存选通信号ALE;T2期间发出读写命令信号RD#、WR#及其它相关信号;T3期间完成数据的访问;T4结束该总线周期。13、结合8086最小模式下总线操作时序图,说明ALE、M/IO#、DT/R#、RD#、READY信号的功能。答:ALE为外部地址锁存器的选通脉冲,在T1期间输出;M/IO#确定总线操作的对象是存储器还是I/O接口电路,在T1输出;DT/R#为数据总线缓冲器的方向控制信号,在T1输出;RD#为读命令信号;在T2输出;READY信号为存储器或I/O接口“准备好”信号,在T3期间给出,否则8086要在T3与T4间插入Tw等待状态。14、什么是总线请求?8086在最小工作模式下,有关总线请求的信号引脚是什么?答:系统中若存在多个可控制总线的主模块时,其中之一若要使用总线进行数据传输时,需向系统请求总线的控制权,这就是一个总线请求的过程。8086在最小工作模式下有关总线请求的信号引脚是HOLD与HLDA。15、简述在最小工作模式下,8086如何响应一个总线请求?答:外部总线主控模块经HOLD引线向8086发出总线请求信号;8086在每个时钟周期的上升沿采样HOLD引线;若发现HOLD=1则在当前总线周期结束时(T4结束)发出总线请求的响应信号HLDA;8086使地址、数据及控制总线进入高阻状态,让出总线控制权,完成响应过程。16、在基于8086的微计算机系统中,存储器是如何组织的?是如何与处理器总线连接的?BHE#信号起什么作用?答:8086为16位处理器,可访问1M字节的存储器空间;1M字节的存储器分为两个512K字节的存储体,命名为偶字节体和奇字节体;偶体的数据线连接D7D0,“体选”信号接地址线A0;奇体的数据线连接D15D8,“体选”信号接BHE#信号;BHE#信号有效时允许访问奇体中的高字节存储单元,实现8086的低字节访问、高字节访问及字访问。17、“80386是一个32位微处理器”,这句话的涵义主要指的是什么?答:指80386的数据总线为32位,片内寄存器和主要功能部件均为32位,片内数据通路为32位。18、80X86系列微处理器采取与先前的微处理器兼容的技术路线,有什么好处?有什么不足?答:好处是先前开发的软件可以在新处理器组成的系统中运行,保护了软件投资。缺点是处理器的结构发展受到兼容的约束,为了保持兼容性增加了硅资源的开销,增加了结构的复杂性。第三章 8086指令系统及汇编语言指令程序简介一、内容概述31 8089指令系统的基本格式微处理器只能识别和执行以二进制代码形式表示的指令,这种指令代码称作机器码。8086CPU的机器码指令有几百条,但它们的基本格式均为16个字节。除了操作码字节和寻址方式字节外,就是单双字节的位移量和单双字节的立即数。 一条指令具体为基本格式中的哪一种,是由指令的操作码和寻址方式决定的,具体地说,在指令操作码中的W、D、S等指示位就是用来指出:指令操作所涉及的是16位数还是8位数;指令中所需的操作数是来自某一寄存器还是由全部数字节给出;当操作数或操作结果存于某一寄存器中时,该寄存器是通过操作码还是寻址方式字节来指定。32 寻址方式8086的寻址方式分为两大类:数据存储器寻址方式和程序存储器寻址方式。(一) 数据存储器寻址方式数据存储器寻址方式实际上是寻找有效地址EA值。在8086微机系统中,知道了有效地址EA后,将其与左移4位后的段寄存器内容相加,就可以算出8086所有的存储器物理地址。因此,在一条指令中,根据其寻址方式求出了EA后很快就可以找到操作数所在的物理地址。(二) 程序存储器寻址方式程序存储器寻址方式要寻找的是当前要执行的指令所在的存储器物理地址。这是由于在执行JUMP指令或CALL指令后,IP的内容须依指令的要求改变,这种改变可能在段内范围进行,也可能在段间进行。在段内或段间改变IP的内容时,其转移地址码可能由指令码直接提供,也可能由寄存器或存储单元提供。于是程序存储器寻址就有了段内直接、段内间接、段间直接、段间间接四种寻址方式。(三) 寻址方式字节8086CPU有着多种灵活的寻址方式,这些寻址方式是通过寻址方式字节即指令码的第二个字节来指定的。寻址方式字节的格式为:其中MOD是用来识别是寄存器寻址方式还是存储器寻址方式的。当MOD11时,为寄存器寻址方式;MOD11时,为存储器寻址方式。REG字段与操作码中的W位一起用来选择指令操作中所使用的寄存器。RM字段与MOD字段一起用来指定寻址方式,它们的组合可以提供24种数据存储器寻址方式以及16种寄存器寻址方式。(四) 段越界前绍所谓“段越界前缀”就是一条特定的指令,该指令功能是把数据所在的当前段寄存器改 为另一个段寄存器,另一个段寄存器由这条特定指令指定。“段越界前缀指令”的格式如下:其中RR值代表当前段被跨越后得访问数据所在段。RR00,01,10,11分别表示ES,CS,SS,DS段寄存器。(五)8086机器语言指令基本格式分析举例在了解了8086机器码指令的基本格式、寻址方式、操作码的指示位、寻址方式字节等有关知识的基础上就可进行机器码指令的分析和阅读了。在周细等编微型计算机极其应用第二版25节中所举的例子就是通过对指令各字节及相应位进行阅读分析,进一步了解、熟识8086的各种寻址方式以及指令在机器中的执行过程,从而达到了解8086指令系统的目的,以便能够熟练使用8086汇编语言进行程序的编制。33 8086汇编语盲语句及基本语法在了解了8086指令的机器语言基本格式及寻址方式的基础上,本节进一步讨论8086的汇编语言指令。重点内容是了解8086各种汇编语言指令的基本格式、功能以及它们在汇编源程序中的应用。在实际应用中的一些语法要求也是本节应重点掌握的内容。 (一)8086的汇编语言指令语句 8086汇编语言语句有三种:指令语句;伪指令语句及宏指令语句。 对指令语句要求能从原理和应用两个方面去理解和掌握。对某一条具体常用的指令语句 (如MOV等),要能知道操作数属什么类型、操作数的寻址方式、实际物理地址是什么,具体常用指令功能以及某几条指令的特殊用途也是应该掌握的。同时由以上分析也应能知道该指令机器码指令格式中对应的指令操作码中指示位及寻址方式字节中MOD字段信息的具体内容。对伪指令语句,要求了解常用的、与汇编源程序密切相关的伪指令功能,同时在阅读汇编源程序时,能对伪指令进行分析;在编写汇编源程序时能正常运用相应的伪指令。对宏指令语句,本节仅要求知道其定义,其余内容不作要求。(二) 汇编语言的有关基本规定及格式对汇编语言源程序的编写,8086是有严格的规定和基本格式的。8086汇编源程序由两大部分组成,一部分是用伪指令按照一定的格式和语法要求写出的汇编语句,另一部分是用指令语句编写的CPU可执行的程序段。用伪指令编写的汇编语句是用来帮助汇编程序在对源程序中CPU可执行程序段进行汇编时能对指令语句中的变量正确赋值,或留出指定的存储区,等等,以便正确汇编,产生出机器可执行的目标程序。进行汇编语言源程序设计时,有关伪指令语句、指令语句所有的基本规定及格式都是应该掌握的内容。二、教学要求掌握8086汇编语言程序设计的基本方法;汇编语言程序有三种基本结构:顺序结构、循环结构及分支结构。要求能了解三种基本结构的基本形式,能阅读分析并编写出简单的程序。掌握转移指令的各条语句格式、功能及应用。在此基础上,能编写一般的简单分支程序,并能结合寻址方式中所介绍的程序地址寻址方式内容,从原理的角度理解转移指令在机器中是如何进行操作的。三、重点难点在使用简单转移指令时,应注意TEST、AND、OR、XOR几条指令的使用。它们的使用可提供相应标志位的状态,作为判断转移分支的测试条件。在测试分支条件时,还常使用移位和循环移位指令,通过这类指令的执行对相应标志位的影响来判断转移分支条件是否满足,以便确定程序的执行方向。对于使用比较指令进行分支程序转移判断,要求能分析阅读相应汇编源程序即可,不要求编写这类程序。对于循环程序,学习重点应为熟悉了解循环程序的结构,能分析一段循环程序的四个组成部分各由哪些语句组成,从而能通过逐条指令的分析说明程序将完成的功能。同时,也能在分析程序的基础上画出程序的流程图。对于多重循环,只需了解其概念,不作更深的要求。应了解子程序的概念、子程序的调用和返回、子程序的定义格式及现场的保护,以及参数在主、子程序之间的传递方式等内容。对于子程序,要求能在程序中对其进行分析,了解某子程序经主程序调用后使主程序实现的功能。四、习题1、根据下列要求编写一个汇编语言程序::代码段的段名为COD_SG数据段的段名为DAT_SG堆栈段的段名为STK_SG变量HIGH_DAT所包含的数据为95将变量HIGH_DAT装入寄存器AH,BH和DL程序运行的入口地址为START答案:DAT_SG SEGEMNTHIGH_DATDB 95DAT_SG ENDS;STK_SG SEGMENTDW64 DUP(?)STK_SG ENDS;COD_SG SEGMENTMAINPROCFARASSUMECS: COD_SG, DS: DAT_SG, SS: STK_SGSTART:MOVAX, DAT-SGMOVDS, AXMOVAH, HIGH_DATMOVBH, AHMOVDL, AHMOVAH, 4CHINT21HMAIN ENDPCOD_SG ENDS END START2、指出下列程序中的错误:STAKSGSEGMENTDB100 DUP(?)STA_SGENDSDTSEGSEGMENTDATA1DB?DTSEGENDCDSEGSEGMENTMAINPROCFARSTART:MOVDS,DATSEGMOVAL,34HADDAL,4FHMOVDATA,ALSTARTENDPCDSEGENDSEND答案: 改正后:STAKSGSEGMENTDB100 DUP(?)STAKSGENDSDTSEGSEGMENTDATA1DB?DTSEGENDSCDSEG SEGMENTMAINPROCFARASSUME CS: CDSEG, DS: DTSEG, SS: STAKSGSTART:MOVAX, DTSEGMOVDS, AXMOVAL, 34HADDAL, 4FHMOVDATA1, ALMOVAH, 4CHINT21HMAINENDPCDSEGENDSEND S3、将下列文件类型填入空格:(1) .obj (2) .exe (3) .crf (4) .asm (5) .lst (6) .map 编辑程序输出的文件有_; 汇编程序输出的文件有_; 连接程序输出的文件有_。答案:编辑程序输出文件: (4)汇编程序输出文件: (1), (3), (5) 连接程序输出文件: (2), (6)4、下列标号为什么是非法的?(1) GET.DATA (2) 1_NUM (3) TEST-DATA(4) RET(5) NEW ITEM答案:非法标号: (1)因为.只允许是标号的第一个字符(2)第一个字符不能为数字 (3)不允许出现-(4)不能是保留字,如助记符 (5)不能有空格5、下面的数据项定义了多少个字节?DATA_1DB6 DUP(4 DUP(0FFH)答案: 24字节6、对于下面两个数据段,偏移地址为10H和11H的两个字节中的数据是一样的吗?为什么?DTSEGSEGMENT |DTSEGSEGMENTORG10H |ORG10HDATA1DB72H |DATA1DW7204HDB04H |DTSEGENDSDTSEGENDS |答案:不一样. 分别是72H, 04H和04H, 72H. 存储字时低8位存在低字节,高8位存在高字节.7、下面的数据项设置了多少个字节?(1) ASC_DATADB1234(2) HEX_DATA DB1234H答案: (1) 设置了4个字节 (2) 设置了2个字节8、执行下列指令后, AX寄存器中的内容是什么?TABLEDW10,20,30,40,50ENTRYDW3 MOVBX,OFFSET TABLEADDBX,ENTRYMOVAX,BX答案:(AX)=409、指出下列指令的错误:(1) MOVAH,BX(2) MOVSI,BX(3) MOVAX,SIDI(4) MOVAX,BXBP(5) MOVBX,ES:AX(6) MOVBYTE PTRBX,1000(7) MOVAX,OFFSET SI(8) MOVCS,AX(9) MOVDS,BP答案: (1) 源、目的字长不一致 (2) 源、目的不能同时为存贮器寻址方式 (3) 基址变址方式不能有 SI和DI的组合 (4) 基址变址方式不能有 BX和BP的组合 (5) 在8086寻址方式中,AX不能作为基址寄存器使用,而且源、目的不能同时为存贮器寻址方式 (6) 1000超出一个字节的表数范围 (7) OFFSET只用于简单变量,应去掉 (8) CS不能作为目的寄存器 (9) 段地址不能直接送入数据段寄存器10、DATASEGMENTTABLE_ADDRDW1234HDATAENDS MOVBX, TABLE_ADDRLEABX, TABLE_ADDR 请写出上述两条指令执行后, BX寄存器中的内容。答案:MOVBX,TABLE_ADDR; 执行后(BX)=1234H LEABX,TABLE_ADDR; 执行后(BX)=OFFSET TABLE_ADDR11、 设(DS)=1B00H, (ES)=2B00H, 有关存储器地址及其内容如右图所示,请用两条指令把X装入AX寄存器。1B00:2000H8000H1B00:2002H2B00H 2B00:8000HX 答案:LES BX, 2000HMOV AX, ES: BX12、变量DATAX和DATAY定义如下: DATAXDW 0148H DW 2316H DATAYDW 0237H DW 4052H按下述要求写出指令序列:DATAX和DATAY中的两个字数据相加, 和存放在DATAY和DATAY+2中。DATAX和DATAY中的两个双字数据相加, 和存放在DATAY开始的字单元中。DATAX和DATAY两个字数据相乘(用MUL)。DATAX和DATAY两个双字数据相乘(用MUL)。DATAX除以23(用DIV)。DATAX双字除以字DATAY(用DIV)。答案:(1)MOVAX, DATAXADDAX, DATAYMOVBX, DATAX+2ADDBX, DATAY+2MOVDATAY, AXMOVDATAY+2, BX(2)MOVAX, DATAXADDDATAY, AXMOVAX, DATAX+2ADCDATAY+2, AX(3)MOVAX, DATAXMULDATAYMOVDATAY,AXMOVDATAY+2,DX(4)MOVAX,WORD PTR DATAXMOVBX,WORD PTR DATAYMULBXMOVRESULT,AXMOVRESULT+2,DXMOVAX,WORD PTR DATAXMOVAX,WORD PTR DATAY+2MULBXADDRESULT+2,AXADCRESULT+4,DXMOVAX,WORD PTR DATAX+2MOVBX,WORD PTR DATAYMULBXADDRESULT+2,AXADCRESULT+4,DXMOVAX,WORD PTR DATAX+2MOVBX,WORD PTR DATAY+2MULBXADDRESULT+4,AXADCRESULT+6,DX (5)MOVAX, DATAXMOVBL, 23DIVBLMOVBL,AHMOVAH, 0MOVDATAY, AX;存放商MOVAL,BLMOVDATAY+2, AX;存放余数(6)MOVAX, DATAXMOVDX, DATAX+2DIVDATAY MOVDATAY, AXMOVDATAY+2, DX13、试分析下面的程序段完成什么操作?MOVCL,04SHLDX,CLMOVBL,AHSHLAX,CLSHRBL,CLORDL,BL答案: 将DX: AX中的双字左移4位(乘16)14、用其他指令完成和下列指令一样的功能: (1) REP MOVSB(2) REP LODSB(3) REP STOSB(4) REP SCASB答案:LOOP1:MOVAL,BYTE PTR SIMOVES:BYTE PTR DI, ALINCSI或:DECSIINCDI或:DECDILOOPLOOP1(2) LOOP1:MOVAL, BYTE PTR SIINCSI或:DECSILOOPLOOP1(3) LOOP1:MOVES:BYTE PTR DI, ALINCDI或:DECDILOOPLOOP1(4) LOOP1:CMPAL,ES:BYTE PTR DIJEEXITINCDI或:DECDILOOPLOOP1EXIT:15、编写程序段, 比较两个5字节的字符串OLDS和NEWS, 如果OLDS字符串与NEWS不同, 则执行NEW_LESS, 否则顺序执行程序。答案:LEASI, OLDSLEADI, NEWSMOVCX, 5CLDREPZCMPSBJNZNEW_LESS16、假定AX和BX中的内容为带符号数, CX和DX中的内容为无符号数, 请用比较指令和条件转移指令实现以下判断:若DX的值超过CX的值,则转去执行EXCEED若BX的值大于AX的值,则转去执行EXCEEDCX中的值为0吗? 若是则转去执行ZEROBX的值与AX的值相减, 会产生溢出吗? 若溢出则转OVERFLOW若BX的值小于AX的值,则转去执行EQ_SMA若DX的值低于CX的值,则转去执行EQ_SMA 答案:(1) CMPDX, CX JAEXCEED(2) CMPBX, AX JGEXCEED(3) CMPCX, 0 JEZERO(4) SUBBX, AX JOOVERFLOW(5) CMPBX, AX JLEQ_SMA(6) CMPDX, CX JBEQ_SMA17、假如在程序的括号中分别填入指令:(1) LOOP L20(2) LOOPNE L20(3) LOOPE L20试说明在三种情况下, 当程序执行完后, AX、BX、CX、DX四个寄存器的内容分别是什么?TITLEEXLOOP.COMCODESGSEGMENTASSUMECS:CODESG, DS:CODESG. SS:CODESGORG100HBEGIN:MOVAX,01MOVBX,02MOVDX,03MOVCX,04L20:INCAXADDBX,AXSHRDX,1( )RETCODESGENDSENDBEGIN答案:(1)(AX)= 5 (BX)= 16 (CX)= 0 (DX)= 0(2)(AX)= 2 (BX)= 4 (CX)= 3 (DX)= 1(3)(AX)= 3 (BX)= 7 (CX)= 2 (DX)= 018、变量N1和N2均为2字节的非压缩BCD数码,请写出计算N1与N2之差的指令序列。答案:MOVAX, 0MOVAL, N1+1SUB AL, N2+1AASMOVDL, ALMOVAL, N1SBB AL, N2AASMOVDH, AL19、有两个3位的ASCII数串ASC1和ASC2定义如下:ASC1DB578ASC2DB694ASC3DB0000请编写程序计算ASC3ASC1+ASC2。答案:CLCMOVCX, 3MOVBX, 2BACK:MOVAL, ASC1BXADCAL, ASC2BXAAAORASC3BX+1, ALDEC BXLOOPBACKRCL CX, 1ORASC3BX, CL20、假设(CS)=3000H, (DS)=4000H, (ES)=2000H, (SS)=5000H, (AX)=2060H, (BX)=3000H, (CX)=5, (DX)=0, (SI)=2060H, (DI)=3000H, (43000H)=0A006H, (23000H)=0B116H, (33000H)=0F802H, (25060)=00B0H,.(SP)=0FFFEH, (CF)=1, (DF)=1, 请写出下列各条指令单独执行完后, 有关寄存器及存储单元的内容, 若影响条件码请给出条件码SF、ZF、OF、CF的值。(1) SBBAX,BX(2) CMPAX,WORD PTRSI+0FA0H(3) MULBYTE PTRBX(4) AAM(5) DIVBH(6) SARAX,CL(7) XORAX,0FFE7H(8) REPSTOSB(9) JMPWORD PYRBX(10) XCHGAX,ES:BX+SI 答案:(1) (AX)=0F05FH, (SF)=1, (ZF)=0, (OF)=0, (CF)=1(2) (SF)=1, (ZF)=0, (OF)=1, (CF)=1(3) (AX)=0240H, (OF)=1, (CF)=1(4) (AX)=0906H, (SF)=0, (ZF)=0(5) (AX)=20ACH(6) (AX)=0103H, (CF)=0(7) (AX)=0DF87H, (CF)=0, (OF)=0, (SF)=1, (ZF)=0(8) (23000H)(23004H)=60H, 不影响标志位(9) (IP)=0A006H, 不影响标志位(10) (AX)=00B0H, (25060)=2060H, 不影响标志位21、试编写一个汇编语言程序,要求对键盘输入的小写字母用大写字母显示出来。答案:abc:movah,1int21hcmpal,ajbstopcmpal,zjastopsubal,20hmovdl,almovah,2int21hjmpabcstop: ret22、编写程序,比较两个字符串STRING1和STRING2所含字符是否完全相同,若相同则显示“MATCH”,若不同则显示“NO MATCH”。答案:datareasegmentstring1dbasfioastring2dbxcviyoafmess1dbMATCH,$mess2dbNO MATCH,$datarea endsprognam segmentmain proc farassume cs:prognam,ds:datareastart:push dssubax,axpush axmovax,datareamovds,axmoves,axbegin: movcx, string2-string1movbx, mess1-string2cmpbx,cxjnzdispnoleadx,addrleasi,string1leadi,string2repecmpsbjnedispnomovah,9leadx,mess1int21hretdispno:movah, 9leadx, mess2int21hretmainendpprognamendsendstart23、试编写程序,要求从键盘输入3个16进制数,并根据对3个数的比较显示如下信息: (1)如果3个数都不相等则显示0; (2)如果3个数中有2个数相等则显示2; (3)如果3个数都相等则显示3。答案:data segmentarraydw3 dup(?)dataendscode segmentmain proc farassume cs:code,ds:datastart:push dssubax,axpush axmovax,datamovds,axmovcx,3leasi,arraybegin:push cxmovcl,4movdi,4movdl, movah,02int21hmovdx,0input:movah,01int21handal,0fhshldx,clordl,aldecdijneinputmovsi,dxaddsi,2popcxloopbegincomp:leasi,arraymovdl,0movax,simovbx,si+2cmpax,bxjnenext1adddl,2next1:cmpsi+4,axjnenext2adddx,2next2:cmpsi+4,bxjnenumadddl,2num:cmpdx,3jldispmovdl,3disp:movah,2adddl,30hint21hretmain endpcodeendsendstart24、已知整数变量A和B,试编写完成下述操作的程序: (1)若两个数中有一个是奇数,则将该奇数存入A中,偶数存入B中; (2)若两个数均为奇数,则两数分别加1,并存回原变量; (3)若两个数均为偶数,则两变量不变。答案:dsegsegmentadw?bdw?dsegendscsegsegmentmainproc farassumecs:cseg,ds:dsegstart:push dssubax,axpush axmovax,dsegmovds,axbegin: movax,amovbx,bxorax,bxtestax,0001jzclasstestbx,0001jzexitxchg bx,amovb,bxjmpexitclass: testbx,0001jzexitincbincaexit:retmainendpcsegendsendstart25、把010010之间的30个数,存入首地址为GRAD的字数组中,GRAD+i表示学号为i+1的学生成绩。另一个数组RANK是30个学生的名次表,其中RANK+I的内容是学号为i+1的学生的名次。试编写程序,根据GRAD中的学生成绩,将排列的名次填入RANK数组中(提示:一个学生的名次等于成绩高于这个学生的人数加1)。答案:dsegsegmentgradedw30 dup(?)rankdw30 dup(?)dsegendscsegsegmentmainprocfarassumecs:cseg, ds:dseg, es:dsegstart:pushdssubax,axpush axmovax,dsegmovds,axmoves,axbegin: movdi,0movcx,30loop1: pushcxmovcx,30movsi,0movax,gradedimovdx,0loop2: cmp gradesi,axjbego_onincdxgo_on: addsi,2looploop2popcxincdxmovrankdi,dxsdddi,2looploop1retmainendpcsegendsendstart26、分析下列程序的功能,写出堆栈最满时各单元的地址及内容。SSEGSEGMENT STACKAT1000H; 堆栈的段地址为1000HDW128 DUP(?) TOSLABELWORDSSEGENDS; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -DSEGSEGMENTDW32 DUP(?)DSEGENDS; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -CSEGSEGMENTMAINPROCFARASSUMECS:CSEG, DS:DSEG,SS:SSEGSTART:
展开阅读全文