当前位置:文档之家› 惠州学院考试 -汇编语言2版习题答案备份

惠州学院考试 -汇编语言2版习题答案备份

惠州学院考试 -汇编语言2版习题答案备份
惠州学院考试 -汇编语言2版习题答案备份

汇编语言程序设计教程(第二版)

习题参考答案

10级考试复习资料整理

老师给的复习资料很少,只是说,大部分实验内容考试出过的

书本上的P47那几个例题P99的题目,计算

第1章计算机基础知识

1.计算机的应用分哪几个方面,请举例说明书中未提到的领域的计算机应用。

科学计算、数据处理、计算机控制、计算机辅助设计、人工智能、企业管理、家用电器、网络应用。

书中未提及的如:远程教育、住宅小区控制、飞行系统控制与管理等。

2.简述计算机的发展过程,请查阅相关资料,列出微机的发展过程。

电子管、晶体管、集成电路、大规模集成电路

以IBM为例,微机的发展:4004、8008、8080、8086/8088、80286、80386、80486、Pentium 系列

3.计算机的字长是怎么定义的,试举例说明。

计算机能同时处理二进制信息的位宽定义为计算机的字长。如8086能同时进行16位二进制数据的运算、存储和传输等操作,该机器的字长为16位。

4.汇编语言中的基本数据类型有哪些?

数值型数据和非数值型数据。非数值数据如字符、字符串、逻辑值等。

6.按要求完成进制转换。

(1)7BCH=011110111100B=1980D

(2)562Q=101110010B=370D

(3)90D=01011010B=5AH

(4)1110100.111B=164.7Q=74.EH

8.列出数字0~9、大写字母A~Z及小写字母a~z的ASCII码值。

30H~39H 41H~5AH 61H~7AH

9.在汇编语言中,如何表示二进制、八进制、十进制和十六进制的数值?

用相应进制的数值加上进制标记即可。

二进制用B,如10101010B

八进制用Q,如437Q。

十进制用D或不用,如54D,或54。

十六进制用H,如27A8H

10.完成下列二进制数的加减运算。

(1)10101010 + 11110000 (2)11001100 + 01010100

=110011010 =100100000

(3)11011010 - 01010010 (4)11101110 - 01001101

=10001000 =10100001

11.完成下列十六进制数的加减运算。

(1)0FEA9 - 8888=7621H (2)0FFFF - 1234=EDCBH

(3)0EAC0 + 0028=EAE8H (4)3ABC + 1678=5134H

12.完成下列BCD码的运算。考试没有出过,老师有提到

(1)3+5 =8

0011+0101=1000 不用进行十进制调整

(2)4+7 =11

0100+0111=1011 此码不是BCD码,需要进行十进制调整

1011+0110=10001=0001,0001

(3)6+5 =11

0110+0101=1011 此码不是BCD码,需要进行十进制调整

1011+0110=10001=0001,0001

(4)8+8 =16

1000+1000=10000 此码不是BCD码,需要进行十进制调整

10000+0110=10110=0001,0110

第2章微型计算机系统概述

1.说明二进制位(bit),字节(byte),字(word),双字(double word)的含义及相互之

间的关系。

位(bit):一个二进制位

字节(byte):8位二进制位

字(word):一般为机器字长,在8086机器中为16位二进制位,即两个字节。

双字(double word):双倍字长,在8086机器中为32位二进制位。

2.一台微型计算机,数据线有8根,地址线有16根,如果采用字节编址,那么它可以访

问的最大存储空间是多少字节?试用十六进制数表示该机的地址范围。

216 = 64KB,0000H~FFFFH

3.8088CPU内部分为哪两个大的功能部件?试述这两个部件的作用是什么?

8088微处理器内部分为执行单元(EU)和总线接口单元(BIU)两部分。

BIU单元用来实现EU的所有总线操作。它由地址加法器,段寄存器CS、DS、SS、ES,指令指针IP,指令队列缓冲器和总线控制逻辑组成。BIU负责CPU与存储器或外部设备之间的信息交换。地址加法器将段和偏移地址相加,生成20位的物理地址。

EU单元负责指令的执行,由算术逻辑单元ALU、标志寄存器F、通用寄存器及EU控

制器等组成,主要进行16位的各种运算及有效地址的计算。EU不与计算机系统总线相关,而从BIU中的指令队列取得指令。这个指令队列中,存放着BIU预先由存储器中取出的若干个字节的指令。

4.8088微处理器中有哪些寄存器?说明它们的功能及分组情况。基础,一定要记得

5.8086的寄存器中,有哪些16位寄存器可分为两个8位寄存器来使用?

AX(AH,AL)、BX(BH,BL)、CX(CH,CL)、DX(DH,DL)

6.8086/8088的标志寄存器F中有哪些标志位?它们的名称和功能是什么?考试出过的具

体不太清楚了,

CF——进位标志(Carry Flag)。若CF=1,表示算术运算时产生进位或借位,否则CF=0。移位指令会影响CF。

PF——奇偶标志(Parity Flag)。若PF=1,表示操作结果中“1”的个数为偶数,否则PF=0。这个标志位主要用于检查数据传送过程中的错误。

AF——辅助进位标志(Auxiliary Carry Flag)。若AF=1表示字节运算产生低半字节向高半字节的进位或借位,否则AF=0。辅助进位也称半进位标志,主要用于BCD码运算的十进制调整。

ZF——全零标志(Zero Flag)。若ZF=1,表示操作结果全为零,否则ZF=0。

SF——符号标志(Sign Flag)。若SF=1,表示符号数运算后的结果为负数,否则SF=0。

OF——溢出标志(Overflow Flag)。若OF=1,表示当进行算术运算时,结果超过了最大范围,否则OF=0。

IF——中断允许标志(Interrupt Enable Flag)。若IF=1,则CPU可以响应外部可屏蔽中断请求;若IF=0,则CPU不允许响应中断请求。IF的状态可由中断指令设置。

DF——方向标志(Direction Flag)。若DF=1,表示执行字符串操作时按着从高地址向低地址方向进行;否则DF=0。DF位可由指令控制。

TF——单步标志(Trace Flag)。又称跟踪标志。该标志位在调试程序时可直接控制CPU 的工作状态。当TF=1时为单步操作,CPU每执行一条指令就进入内部的单步中断处理,以便对指令的执行情况进行检查;若TF=0,则CPU继续执行程序。

7.80386有哪几种工作方式?简述每种工作方式的特点。

80386有三种工作方式:实地址方式、保护方式和虚拟8086方式。

实地址方式——80386在实地址方式下的工作原理与8086相同,主要差别是80386可以处理32位的数据,如进行32位的寄存器的运算,以及偏移地址在64KB以内的32位的数据传送。另外,在实地址方式下80386新增加的两个段寄存器FS和GS是可用的。实地址方式是80386复位后立即出现的工作方式。

保护方式——80386在保护方式下可以访问4G字节的物理存储空间,段的长度在启动页功能时是4G字节,不启动页功能时是1M字节,页功能是可选的。在此方式下,可以引入虚拟存储器的概念,以扩充软件所占有的存储器空间。保护方式是支持多任务的方式,提供了一系列的保护机制,如任务地址空间的分离、0~3共四个特权级、特权指令、段和页的访问权限(只读或只执行等)以及段限检查。

虚拟8086方式——这是一种既有保护功能,又能执行8086代码的工作方式,是一种动态方式。在此方式下,80386能够迅速、反复进行虚拟8086方式和保护方式的切换。从保护方式进入虚拟8086方式执行8086程序,然后离开虚拟8086方式,进入保护方式继续执行固有的80386程序。

8.80486有哪些寄存器?简述各寄存器的功能。

9.Pentium有哪些主要的寄存器,简述各组寄存器的功能。

Pentium的寄存器组织可以分成三大类,即基本寄存器组、系统寄存器组和浮点寄存器组。其中系统寄存器组只供系统程序访问,其他两组寄存器则供系统程序和应用程序共同访问。Pentium微处理器对80486的寄存器作了一些扩充。EFLAGS标志寄存器增加了两位:VIF(位19)和VIP(位20),它们用于控制Pentium虚拟8086方式扩充部分的虚拟中断。控制寄存器CR0的CD位和NW位被重新定义以控制Pentium的片内高速缓存,并新增了CR4控制寄存器对80486结构扩充。此外,还增加了几个模式专用寄存器,用于控制可测试性、执行跟踪、性能检测和机器检查错误等功能。

10.在8086系统中,段地址和偏移地址如下所示,请分别计算它们的物理地址考试虽没有

出来,建议看,

(1)F000:0100 物理地址为:F0000H+0100H=F0100H

(2)2350:1ABC物理地址为:23500H+1ABCH=24FBCH

(3)3200:1234物理地址为:32000H+1234H=33234H

(4)5000:010E物理地址为:50000H+010EH=5010EH

(5)10E0:2020物理地址为:10E00H+2020H=12E20H

(6)2010:1020物理地址为:20100H+1020H=21120H

(7)1000:1000物理地址为:10000H+1000H=11000H

(8)C0C0:C0C0物理地址为:C0C00H+C0C0H=CCCC0H

11.从8086开始的所有80x86系列微机系统中,寻址内存的地址总线有多少位?内存的寻

12.简述上题所涉及的各种微机系统的内存组织方式。

8086:存储器分段管理。

80286:存储器分段管理,在保护方式下,存储器寻址使用32位指针,包含一个16位的选择子分量和一个16位的偏移量分量。但选择子的内容不再是一个物理存储器的地址的高16位,而是进入某一个存储器常驻表的变址值,所要求的段的24位段基地址要从存储器中的表内取得。16位偏移量用来加到段基址上,形成24位的物理地址

80386:CPU可直接寻址的物理空间达4GB,除了保留存储器分段管理外,还增加了内存分页管理。

80386的段选择寄存器是在80286选择寄存器基础之上新增了两个支持当前数据段的段选择寄存器FS和GS,与段选择寄存器相关联的段描述符高速缓冲器扩充到64位。

80486:80486具有32位的内存地址空间,对存储器段的访问采用段描述符管理机制。具有三种工作方式,即实地址方式、虚拟地址保护方式和虚拟8086方式。在虚拟地址保护方式下,可寻址4GB物理地址空间以及64TB虚拟地址空间。

80486内部的存储器管理部件MMU由分段部件和分页部件组成。分段部件用来把指令给出的逻辑地址转换成线性地址,并对逻辑地址空间进行管理,实现多任务之间存储器空间的隔离和保护,同时也实现了指令和数据区的再定位。分页部件用来把线性地址转换成物理地址,并对物理地址空间进行管理,实现虚拟存储器技术。

Pentium:地址总线仍为32位,因此物理寻址范围仍为4GB。Pentium微处理器在工作方式方面,还增加了一种“系统管理方式(SMM)”,以实现对电源和OS进行管理等高级功能。

13.简述从8086到Pentium微处理器在组成结构上的变化,分析这些变化,你能得出什么

结论?

8086:8086微处理器内部分为执行单元(EU)和总线接口单元(BIU)两部分。BIU 单元用来实现EU的所有总线操作,EU单元负责指令的执行。

80286:在内部结构上,8086中的总线接口部件BIU在80286中又分成了地址部件AU、指令部件IU和总线部件BU,从而加快了处理器的运行速度。

80386:80386的内部结构由总线接口单元、指令预取部件、指令译码部件、执行部件、分段部件和分页部件6个逻辑功能部件组成,每个部件都能独立操作,又可以对同一条指令的不同部分同时并行操作,使多条指令重叠进行,大大提高了CPU的速度。80386是对80286微处理器的彻底改进,在内存管理和处理速度上比80286之前的CPU有了很大的突破,是一种功能完善高可靠性的CPU,并在目标代码上保持与8086、80286的向上兼容。

80486:80486芯片的内部结构由总线接口、高速缓存、指令预取、指令译码、控制、算术逻辑运算、浮点运算、分段和分页九大部件组成。这些部件可以重叠工作,并构成五级流水线的指令处理。芯片内具有8KB的数据/指令高速缓存Cache,可为频繁访问的数据和

指令提供高速缓存,从而加快CPU与存储器之间的信息交换。片内集成了浮点运算部件,可支持32位、64位和80位的浮点算术运算。由于与CPU之间的数据通道总线加宽,而引线缩短,它们之间的信息交换速度也得到提高。片内具有存储管理部件MMU,可支持对存储器地址实施管理和对存储器空间进行保护。

Pentium:Pentium微处理器的基本组成包括总线接口部件、分页部件、片内Cache存储器、浮点部件、控制部件、执行部件以及分支目标缓冲器等。Pentium提供了一个称为分支目标缓冲器BTB(Branch Target Buffer)的1KB的Cache来动态地预测程序的分支操作。Pentium芯片内部集成了16KB的Cache,其中8KB作为数据Cache,另外8KB作为指令Cache,这两个超高速的Cache可以并行工作。将指令Cache和数据Cache分离的目的是使指令预取和数据操作之间可能发生的冲突降至最低,从而提高CPU的效率。浮点指令流水线具有8级,实际上它是U流水线的扩充。U流水线的前4级用来准备一条浮点指令,浮点部件中的后4级执行特定的运算操作并报告执行错误。

CPU内部的功能部件数量增加,集成度依次提高,将某些原在CPU外部的功能部件集成到CPU内部,功能越来越完善。

第3章微型计算机的指令系统

1.8086/8088指令系统中操作数的类型有哪几种?关于操作数的寻址方式有哪几类?

考试出过的

立即数、寄存器数和内存单元数。

立即寻址、寄存器寻址、寄存器间接寻址、直接寻址、寄存器相对寻址、基址加变址寻址、基址加变址相对寻址。

2.指出段地址、偏移地址与物理地址之间的关系。有效地址EA又是指什么?

段地址左移四位加上偏移地址形成20位的物理地址。

EA是指段内偏移地址,即表示段内某单元相对于段起始地址的空间位置。

3.指出能用于寄存器间接寻址及变址寻址的寄存器有哪些?它们通常与哪个段寄存器配

合形成物理地址?

能用于寄存器间接寻址及变址寻址的寄存器有基址寄存器BX和BP,变址寄存器SI和DI,BX、SI、DI与DS配合形成物理地址,而BP与SS配合形成物理地址。

4.与8086相比,80386的堆栈操作类指令有那些改变?

5.简述80386微处理器中“系统设置和测试指令”的功能。

系统设置和测试指令80386新增加的,它们一般出现在操作系统中,用于对系统的设置和测试。

(1)清除TS标志指令CLTS,这条指令用来清除机器状态字中的任务切换标志TS。

(2)存储全局/局部/中断描述符表寄存器指令SGDT/SLDT/SIDT,这三条指令分别将全局描述符表寄存器、局部描述符表寄存器或中断描述符表寄存器的内容送到存储器中。

(3)装入全局/局部/中断描述符表寄存器指令LGDT/LLDT/LIDT,这三条指令分别将存储器中的字节装入全局描述符表寄存器、局部描述符表寄存器或中断描述符表寄存器。局部描述符表寄存器为两个字节,其他两个寄存器为六字节宽。

(4)存储任务寄存器指令STR,例如:STR [EBX] ;将任务寄存器的两个字节内容送到内存,内存首字节地址由EBX指出。

(5)装入任务寄存器指令LTR,这条指令一般用于多任务操作系统中,它将内存中两个字节装入任务寄存器TR。执行LTR指令后,相应的任务状态段TSS标上“忙”标志。

(6)装入访问权指令LAR,本指令将两个字节选择子中的访问权字节送到目的寄存器。

(7)装入段界限值指令LSL,LSL将描述符中的段界限值送目的寄存器,在指令中,由选择子来指出段描述符。

(8)检测段类型指令VERR/VERW,VERR检测一个选择子所对应的段是否可读,VERW则检测一个选择子所对应的段是否可写。

(9)调整请求特权级指令ARPL,这条指令的功能为调整选择子的RPL字段,由此常用来阻止应用程序访问操作系统中涉及安全的高级别的子程序。ARPL的第一个操作数可由存储器或寄存器指出,第二个操作数则必定为寄存器。如果前者的RPL(最后两位)小于后者的RPL,则ZF置为1,且将前者的RPL增值,使其等于后者的RPL;否则,ZF=0,并不改变前者的RPL。

(10)存储机器状态字指令SMSW,将机器状态字MSW存到内存指定单元对应的两个字节中。

(11)装入机器状态字指令LMSW

本指令将存储器中两个字节送到机器状态字MSW中,通过这种方式,可以使CPU切换到保护方式。

6.列出80486和Pentium微处理器新增加的指令,并简述每条指令的功能。

除了浮点操作指令系统外,80486新增加了6条指令。

(1)BSW AP

双字交换。使32位寄存器中的操作数按字节首尾交换,即D31~D24与D7~D0交换,D23~D16与D15~D8交换。

(2)XADD

将源操作数与目的操作数交换并相加,其中源操作数必须为寄存器,而目的操作数可以是寄存器也可以是内存单元,然后相加,其结果存放在源寄存器中。

(3)CMPXCHG

比较与交换。该指令使用3个操作数:一个寄存器中的源操作数、一个寄存器或内存储器单元的目的操作数和一个隐含(不出现在用户所书写的指令中)的累加器(AL/AX/EAX)。如果目的操作数与累加器的值相等,源操作数送目的单元,否则将目的操作数送累加器。

(4)INVD

Cache无效指令。擦除整个片内Cache,使之无效,并且启动一个擦除总线周期,使外部电路清除片外二级Cache的内容。

(5)WBINVD

Cache无效且回写指令。擦除整个片内Cache,使之无效,并启动一个回写总线周期,将片外二级Cache中的数据回写到内存中,再清除二级Cache中的内容。

(6)INVLPG

转换检测缓冲器TLB无效指令。该指令带有一个操作数,指示TLB中的某一项,使之无效。

与80486相比,Pentium新增加了3条处理器专用指令和5条系统控制指令,但某些新增的指令是否有效与Pentium的型号有关,可利用处理器特征识别指令CPUID判别处理器是否支持某些新增指令。

1、处理器特征识别指令CPUID

根据EAX中的参数,将处理器的说明信息送EAX,特征标志字送EDX。

2、8字节比较交换指令CMPXCHG8B

该指令带有一个内存储器单元操作数。它能实现将EDX:EAX中的8字节值与指定的8字节存储器操作数相比较,若相等,则使ZF=1,且将ECX:EBX中的值送指定的8字节存储单元替换原有的存储器操作数;否则使ZF=0,且将指定的8字节存储器操作数送EDX:EAX。

3、读时间标记计数器指令RDTSC

将Pentium中的64位时间标记计数器的高32位送EDX,低32位送EAX。该计数器随每一个时钟递增,在Reset后该计数器被置0。利用该计数器可检测程序运行性能。

4、读模型专用寄存器指令RDMSR

将ECX所指定的模型专用寄存器的内容送EDX、EAX,具体来说,高32位送EDX,低32位送EAX。若所指定的模型寄存器不是64位,则EDX、EAX中的对应位无定义。

5、写模型专用寄存器指令WRMSR

将EDX、EAX的内容送到由ECX指定的模型专用寄存器。具体来说,EDX和EAX的内容分别作为高32位和低32位。若指定的模型寄存器有未定义或保留的位,则这些位的内容不变。

6、复位到系统管理模式指令RSM

7、将32位寄存器中的内容送控制寄存器CR4的指令

格式为:MOV CR4,R32

8、将控制寄存器CR4的内容送32位寄存器的指令

格式为:MOV R32,CR4

7.什么是堆栈操作?以下关于堆栈操作的指令执行后,SP的值是多少?

PUSH AX

PUSH CX

PUSH DX

POP AX

PUSH BX

POP CX

POP DX

堆栈被定义为一种先进后出的数据结构,即最后进栈的元素将被最先弹出来。堆栈从一个称为栈底的位置开始,数据进入堆栈的操作称为压入(或压栈),数据退出堆栈的操作称为弹出,每进行一次弹出操作,堆栈就减少一个元素,最后一次压入的元素,称为栈顶元素,压入弹出操作都是对栈顶元素进行的堆栈的两种基本的操作。

在进行以上一系列堆栈操作后,SP指针的值是原SP+2。

8.用汇编语言指令实现以下操作。考试出过类型题

(1)将寄存器AX、BX和DX的内容相加,和放在寄存器DX中。

ADD AX,BX

ADD DX,AX

(2)用基址变址寻址方式(BX和SI)实现AL寄存器的内容和存储器单元BUF中的一个字节相加的操作,和放到AL中。

ADD AL,BYTE PTR [BX][SI]

(3)用寄存器BX实现寄存器相对寻址方式(位移量为100H),将DX的内容和存储单元中的一个字相加,和放到存储单元中。

ADD 100H[BX],DX

(4)用直接寻址方式(地址为0500H)实现将存储器中的一个字与立即数3ABCH相加,和放回该存储单元中。

ADD [0500H],3ABCH

(5)用串操作指令实现将内存定义好的两个字节串BUF1和BUF2相加后,存放到另一个串BUF3中的功能。

……

MOV CX,COUNT

MOV SI,OFFSET BUF1

MOV DI,OFFSET BUF3

MOV BX,OFFSET BUF2

AGAIN:LODSB

ADD AL,[BX]

STOSB

INC BX

DEC CX

JNZ AGAIN

……

9.指出下列指令中,源操作数及目的操作数的寻址方式。考试出过类型题

(1)SUB BX,[BP+35] ;寄存器寻址、寄存器相对寻址

(2)MOV AX,2030H ;寄存器寻址、立即寻址

(3)SCASB ;隐含操作数为寄存器寻址和寄存器间接寻址

(4)IN AL,40H ;寄存器寻址、立即寻址

(5)MOV [DI+BX],AX ;基址加变址寻址、寄存器寻址

(6)ADD AX,50H[DI] ;寄存器寻址、寄存器相对寻址

(7)MOV AL,[1300H] ;寄存器寻址、直接寻址

(8)MUL BL ;寄存器寻址、目的操作数为隐含寄存器寻址

10.已知(DS)= 1000H,(SI)= 0200H,(BX)= 0100H,(10100H)= 11H,(10101H)=

22H,(10600H)= 33H,(10601H)= 44H,(10300H)= 55H,(10301H)= 66H,(10302H)= 77H,(10303H)= 88H,试分析下列各条指令执行完后AX寄存器的内容。考试出过类型题

(1)MOV AX,2500H (AX)=2500H

(2)MOV AX,500H[BX] (AX)==4433H

(3)MOV AX,[300H] (AX)=6655H

(4)MOV AX,[BX] (AX)=2211H

(5)MOV AX,[BX][SI] (AX)=6655H

(6)MOV AX,[BX+SI+2] (AX)=8877H

11.判断下列指令是否有错,如果有错,说明理由。考试出过类型题

(1)SUB BL,BX ;两个操作数的宽度不一样

(2)MOV BYTE PTR[BX],3456H ;将16位的立即数传送到一个字节的内存单元(3)SHL AX,CH ;移位指令的移位位数用CL给出,不能用CH。

(4)MOV AH,[SI][DI] ;不能用两个变址寄存器来实现寻址操作

(5)SHR AX,4 ;只有当移位位数为1时,才能用立即数表达

(6)MOV CS,BX ;不能对CS实现传送操作

(7)MOV 125,CL ;立即数不能做目的操作数

(8)MOV AX,BYTE PTR[SI] ;源操作数限定为字节,与目的操作数宽度不一致(9)MOV [DI],[SI] ;两个操作数不能同时为内存数

12.设(DS)= 1000H,(ES)= 2000H,(SS)= 3000H,(SI)= 0080H,(BX)= 02D0H,

(BP)= 0060H,试指出下列指令的源操作数字段是什么寻址方式?它的物理地址是多少?考试出过类型题

(1)MOV AX,0CBH 立即寻址

(2)MOV AX,[100H] 直接寻址,物理地址为:10100H

(3)MOV AX,[BX] 寄存器间接寻址,物理地址为:102D0H

(4)MOV AX,[BP] 寄存器间接寻址,物理地址为:20060H

(5)MOV AX,[BP+50] 寄存器相对寻址,物理地址为:200B0H

(6)MOV AX,[BX][SI] 基址加变址寻址,物理地址为:10350H

13.分别说明下列每组指令中的两条指令的区别.考试出过类型题

(1)AND CL,0FH 按位相“与”,高4位为“0000”,低4位保留原值;

OR CL,0FH 按位相“或”,高4位为原值,低4位为“1111”。

(2)MOV AX,BX 将BX寄存器的内容传送到AX寄存器中;

MOV AX,[BX] 将BX寄存器所指的内存单元的内容送AX寄存器中。

(3)SUB BX,CX BX寄存器内容减去CX寄存器的内容,结果送回到BX;

CMP BX,CX BX内容减去CX内容,但结果不送回,而根据标志位的情况做进一步的动作。

(4)AND AL,01H AL内容与01H相“与”,结果为“0000000x”送回AL寄存器;

TEST AL,01H AL内容与01H相“与”,结果为“0000000x”不送回AL 寄存器,而根据标志位(ZF)情况做进一步的动作。

(5)JMP NEAR PTR NEXT NEXT所指指令在当前指令的同段内(16位地址范围);

JMP SHORT NEXT NEXT所指指令在当前指令的8位地址范围内。

(6)ROL AX,CL 循环左移,进位标志位不参与循环;

RCL AX,CL 循环左移,进位标志位参与循环。

(7)PUSH AX 将AX内容存入栈顶指针处,即进栈操作;

POP AX 将栈顶内容弹出装入AX寄存器中,即出栈操作。

14.试分析以下程序段执行完后BX的内容为何?

MOV BX,1030H

MOV CL,3

SHL BX,CL

DEC BX

程序执行完后,BX=817FH,执行过程如下。

15.写出下列指令序列中每条指令的执行结果,并在DEBUG环境下验证,注意各标志位的

变化情况。

MOV BX,126BH

ADD BL,02AH

MOV AX,2EA5H

ADD BH,AL

SBB BX,AX

ADC AX,26H

SUB BH,-8

第4章8086/8088汇编语言

1.8086汇编语言指令由几部分组成?各部分的作用是什么?

[名字] 指令操作符[操作数] [;注释]

名字可以是常量名、变量名、过程名、段名等标识符等,起标识和标记的作用;指令操作符字段说明指令的功能;操作数字段提供指令操作所需要的源数据和目的数据;注释字段用于程序员对语句或程序段落进行解释说明,增加可读性。

2.请解释变量和标号的含义,两者有何区别?

所定义内存单元的名称为变量,可进行读、写操作,一般为数据区。

标号是某条指令的地址标记,在代码段。

3.试描述汇编语言源程序的一般结构。

STACK SEGMENT STACK

DW 256 DUP(?)

STACK ENDS

DA TA SEGMENT

……

DA TA ENDS

CODE SEGMENT

ASSUME CS:CODE,SS:STACK,DS:DATA

START:……

……

CODE ENDS

END START

4.开发汇编语言源程序的主要步骤有哪些?

首先用EDIT等编辑程序产生汇编语言的源程序,源程序是用汇编语言的语句编写的且

不能为机器所识别的程序,所以要经过汇编程序加以翻译,因此汇编程序的作用就是把源文件转换成用二进制代码表示的目标文件(称为OBJ文件)。在转换的过程中,如果源程序中有语法错误,则汇编结束后,汇编程序将指出源程序中的错误信息,如非法格式,未定义的助记符、标号,漏掉操作数等。用户还可以用编辑程序来修改源程序中的错误,最后得到无语法错误的目标文件。目标文件虽然已经是二进制文件,但它还不能直接上机运行,必须经过连接程序(LINK)把目标文件与库文件或其他目标文件连接在一起形成可执行文件(EXE 文件),才可以在机器上运行。

5.数值返回运算符有哪几种?简述LENGTH与SIZE的区别。

数值返回运算符有TYPE、LENGTH、SIZE、OFFSET和SEG5种。这些操作符把一些特征或存储器地址的一部分作为数值回送,但不改变原操作数的属性。其中:TYPE是类型操作符。

LENGTH是分配单元长度操作符。

SIZE是分配字节操作符。

OFFSET是偏移量操作符。

SEG是段基址操作符。

且有关系:SIZE=TYPE*LENGTH。

6.在BUF1变量中依次存储了5个字数据,接着定义了一个名为BUF2的字单元,表

示如下:

BUF1 DW 8765H,6CH,0,1AB5H,47EAH

BUF2 DW ?

(1)设BX中是BUF1的首地址,请编写指令将数据50H传送给BUF2单元。

ADD BX,10

MOV WORD PTR[BX],50H

(2)请编写指令将数据FFH传送给数据为0的单元。

ADD BX,4

MOV WORD PTR[BX],FFH

7.下面是一个数据段的定义,请用图表示它们在内存中存放的形式。

DA TA SEGMENT

A1 DB 25H,35H,45H

A2 DB 3 DUP(5)

A3 DW 200,3AB6H

A4 DW 3000H,6A6FH

DA TA ENDS

A1

A2

A3

A4

8.说明下列语句所分配的存储空间及初始化的数据值。考试出过类型题

(1)BYTE_V AR DB ‘BYTE’,21,-42H,3 DUP(0,?,2 DUP(2,3),?)有一些改动,

(2)WORD_V AR DW 5 DUP(4,2,0),?,-8,‘BY’,‘TE’256H

BYTE_V AR WORD_V AR

9.在下列数据传送程序段中有些使用不当的语句,请改正之。考试出过类型题

A D

B 10H,20H,‘OPQ’,4FH

B DB N DUP(?);改为B DB 6 DUP(?)

MOV DI,A ;改为MOV DI,OFFSET A

MOV SI,B ;改为MOV SI,OFFSET B

MOV CX,LENGTH A ;改为MOV CX,LENGTH B

CC:MOV AX,[DI]

MOV [SI],AX

INC SI

INC DI

DEC CX ;去掉该句

LOOP CC

10.以下程序段落拟实现在同一个段内的调用过程,试判断可行性,如不能实现,请改

正。

CODE SEGMENT

ASSUME CS:CODE

BEGIN:

CALL SUB1

CALL SUB2

SUB1 PROC FAR

MOV AX,X

MOV BX,Y

MUL BX

RET

SUB1 ENDP

CODE ENDS

END START

SUB1应为NEAR型,过程SUB2并未定义,应定义SUB2。程序段落改为:

CODE SEGMENT

ASSUME CS:CODE

BEGIN:

CALL SUB1

CALL SUB2

SUB1 PROC NEAR

MOV AX,X

MOV BX,Y

MUL BX

RET

SUB1 ENDP

SUB2 PROC NEAR

……

RET

SUB2 ENDP

CODE ENDS

END BEGIN

11.有一个数据段定义了如下6个变量,请写出该数据段。

(1)BUF1为十进制数字节变量:64;

(2)BUF2为字符串变量:‘Teacher’;

(3)BUF3为十六进制数字节变量:2FH;

(4)BUF4为双字变量:657AH;

(5)BUF5为字变量:657AH;

(6)BUF6为二进制数字节变量:10101101B。

DA TA SEGMENT

BUF1 DB 64

BUF2 DB ‘Teacher’

BUF3 DB 2FH

BUF4 DD 657AH

BUF5 DW 657AH

BUF6 DB 10101101B

第5章高级汇编技术

1.何谓宏指令?宏指令在程序中如何被调用?宏指令定义和子程序有什么区别?

在编写程序过程中,若遇到一些要多次使用的程序段,为了简化程序,通常采用定义子程序的方法,同样,也可以采用宏定义的方法来达到这个目的。宏定义是源程序中一段有独立功能的程序代码。但必须先将这一段程序定义为一条宏指令,并具有一个相应的宏指令名,在程序中就可以多次调用它,调用时只需要引用一个宏指令名来代替这一段程序就可以了。

宏定义:

格式为:宏名MACRO [形参表]

┇(宏体)

ENDM

子程序定义:

格式为:过程名PROC [类型]

┇(过程体)

过程名ENDP

2.结构数据类型如何说明?结构变量如何定义?结构字段如何引用?

定义结构的格式为:

结构名STRUC

[字段名] (数据类型定义语句)

结构名ENDS

定义结构变量:

结构变量名结构名〈字段值表〉

引用结构变量的一般格式为:

结构变量名

引用结构变量的字段的一般格式为:

结构变量名﹒字段名

3.试述宏指令与子程序的区别。

宏与子程序有本质的区别,主要反映在调用方式、传递参数和使用细节上。

子程序和宏定义都可以节省存储空间及程序设计所花的时间,可提供模块化程序设计的条件,便于程序的调试及修改等。但是在子程序结构中,为转子程序和返回、保存及恢复寄存器以及参数的传递等操作都要增加程序的开销,这些操作所消耗的时间以及它们所占用的存储空间,都是为取得子程序结构使程序模块化的优点而增加的额外开销。因此,在子程序本身较短或者是需要传递的参数较多的情况下使用宏汇编技术。

子程序是在程序执行期间由主程序调用的,它只占有它自身大小的一个空间,它不仅是源程序级别的简化,还是目标程序级的简化,形成的目标代码较短;而宏调用则是在汇编期间展开的,每调用一次就把宏定义体展开一次,它是源程序级的简化。因而它占有的存储空间与调用次数有关,调用次数越多则占有的存储空间也越大。如果宏调用次数较多的话,则其空间上的开销也是应该考虑的因素。

宏调用的参数通过形参、实参结合实现传递,简洁直观、灵活多变。子程序需要利用寄存器、存储单元或堆栈等传递参数。对宏调用来说,参数传递错误通常是语法错误,会由汇编程序发现;而对子程序来说,参数传递错误通常反映为逻辑或运行错误,不易排除。

4.用条件汇编实现:如果AL寄存器的值小于20,则对语句块1进行汇编,否则对语句

块2进行汇编。

IF AL LT 20

语句块1

ELSE

语句块2

ENDIF

5.记录数据类型如何说明?简述MASK和WIDTH运算符的功能。

<记录名> RECORD <字段名>:<宽度>[=<表达式>]

[,<字段名>:<宽度>[=<表达式>]┅┅]

说明:记录定义时,记录名和字段名不能省略。字段的宽度是指相应字段占的二进制位数,且所有的字段宽度之和不能大于16。如宽度之和大于8位,该记录按字处理,否则按

字节处理。表达式是给字段赋的初值。

MASK运算符返回一个8位或16位的二进制数,在这个数中,记录字段名所指定的字段的对应位为1,其他位为0。

WIDTH运算符返回记录长度或记录字段在记录中所占的二进制位数。

6.定重复汇编与不定重复汇编有哪些区别?

定重复汇编使汇编程序对重复体作重复汇编,以整数表达式的值作为重复次数。

不定重复汇编使汇编程序对重复体作重复汇编,汇编时,依次将参数表中的参数取出代替形参,重复体部分的语句序列的重复次数由参数表中的参数个数决定。

7.使用重复汇编结构,在内存建立起0~9的立方值表。

NUM1=0

REPT 10

NUM2=1

NUM2=NUM2*NUM1

DW NUM2*NUM1

NUM1=NUM1+1

ENDM

8.可以实现条件汇编的伪指令有几条,简述这些伪指令之间的区别。

9.下面是用STRUC伪指令定义的参数表SUBLIST,请定义结构变量以实现此结构的存储

区的分配。

SUBLIST STRUC

MXLEN DB 60

ACLEN DB ?

SUBIN DB 60 DUP(‘’)

SUBLIST ENDS

结构变量定义如下:

LIST1 SUBLIST < >

10.编写宏定义DISPLAY,使其能在当前光标位置显示字符串,字符串的首地址由BX寄

存器指出。

DISPLAY MACRO

MOV DX,BX

MOV AH,9

INT 21H

ENDM

11.编写宏定义SUM,其功能是将一组数据累加。数据存放的首地址在SI寄存器中,数据

的个数在CL寄存器中。

SUM PROC SUMM

MOV AX,0

LOP:ADD AX,[SI]

INC SI

DEC CL

JNZ LOP

ENDM

12.定义20名教师的记录变量,通过输入数据得到教师的基本信息,然后统计年龄满40

岁的男教师的人数。

DA TA SEGMENT

TEACHER RECORD NUM:4,SEX:1,AGE:6,MAJOR:5

ARRAY TEACHER 40 DUP (< >)

COUNT DB 0

DA TA ENDS

CODE SEGMENT

ASSUME CS:CODE,DS:DA TA

START:PUSH DS

MOV AX,0

PUSH AX

MOV AX,DA TA

MOV DS,AX

MOV CH,40

MOV BX,OFFSET ARRAY

NEXT:MOV AX,[BX]

TEST AX,MASK SEX

JZ NEXT1

MOV CL,AGE

MOV DX,MASK AGE

AND AX,DX

SHR AX,CL

CMP AL,40

JL NXET1

INC COUNT

NEXT1:ADD BX,2

DEC CH

JNE NEXT

RET

CODE ENDS

END START

13.编程实现如下功能:如果变量A=‘MA32’,则汇编MOV RESULT,0,否则汇编MOV

RESULT,1。

IF A=‘MA32’

MOV RESULT,0

ELSE

MOV RESULT,1

ENDIF

14.定义一个能实现多个字节数据连减功能的宏,即(a -b -c -d - ┄)→RESULT,减数

的个数存放在某内存单元中,最后结果RESULT存入另一内存单元中。

SUBM MACRO X,Y,Z

MOV DI,OFFSET X

MOV CX,[DI]

MOV DI,OFFSET Y

MOV AX,[DI]

INC DI

LOP:SUB AX,[DI]

INC DI

DEC CX

JNZ LOP

MOV DI,OFFSET Z

MOV [DI],AX

ENDM

第6章汇编语言程序设计

1.在8086/8088汇编语言中,如何实现过程的定义与调用。

子程序的定义是由过程定义伪指令来实现的,一个过程是一段程序,以PROC伪指令语句开始,以ENDP伪指令语句结束。格式如下:

过程名PROC [NEAR或FAR]

┇过程体语句

RET

过程名ENDP

子程序(过程)调用指令CALL的格式为:

CALL OPRD

2.在8086/8088汇编语言中,调用程序与子程序(过程)传递参数的方法有哪几种?

(1)利用寄存器传递参数

这是最常用的一种方法,但受到寄存器个数的限制,一般用于参数较少的情况。在主程

汇编语言程序设计练习题

汇编语言程序设计练习题 一、字符与串处理类 1.逆序输出字符串“BASED ADDRESSING”。 2.试编写一段程序,要求对键盘输入的小写字母用大写字母显示出来。 3.编写程序,从键盘接收一个小写字母,然后找出它的前导字符和后续字符,再按顺序显示这三个字符。 4.从键盘上输入一系列以$为结束符的字符串,然后对其中的非数字字符计数,并显示计数结果。 5.从键盘上输入一串字符(用回车键结束,使用0A号功能调用。)放在STRING中,试编制一个程序测试字符串中是否存在数字。如有,则把CL的第5位置1,否则将该位置置0。 6.从键盘上输入一串字符(用回车键结束,使用0A号功能调用。),将其中的小写英文字母变换为大写英文字母,其他字符保持不变。然后将变换后的字符串显示出来。 7.试编制一个程序:从键盘输入一行字符,要求第一个键入的字符必须是空格符,如不是,则退出程序;如是,则开始接收键入的字符并顺序存放在首地址为buffer的缓冲区中(空格符不存入),直到接收到第二个空格符时退出程序。 8.试编写一段程序,要求比较两个字符串string1和string2所含字符是否相等,如相等则显示“MATCH”, 若不相同则显示“NO MATCH”。 9.试编写一段程序,要求输入两个字符串,如两个字符串相等则显示“MATCH”, 否则显示“NO MATCH”。 10.试编写一段程序,要求在长度为100H字节的数组中,找出大于61H的无符号数的个数并存入字节单元UP中,找出小于2FH的无符号数的个数并存入字节单元DOWN中。 11.在内存区域0B800:0000-0B800:0FFFF(都是16进制数)内查找首地址为SOURCE的串(SOURCE的首字节为串长度),如果找到,则把AL的第0位置0,否则将该位置置1。 12.已知数组A包含15个互不相等的整数,数组B包含20个互不相等的整数。试编制一个程序,把既在A中又在B中出现的整数存放于数组C中。 13.在附加段中,有一个首地址为LIST和未经排序的字数组。在数组的第一个字中,存放着该数组的长度,数组的首地址已存放在DI寄存器中,AX寄存器中存放着一个数。要求编制一个程序:在数组中查找该数,如果找到此数,则把它从数组中删除。 二、数字输入输出类 1. 试编制一个程序,把BX寄存器内的二进制数以十六进制数的形式在屏幕上显示出来。 2. 试编制一个程序,把BX寄存器内的二进制数以八进制数的形式在屏幕上显示出来。 3. 试编制一个程序,把BX寄存器内的二进制数以十进制数的形式在屏幕上显示出来。 4.从键盘上输入2个一位数,求出它们的和(假设和不超过1位)。 5.试编写一段程序,从键盘接收一个四位的十六进制数,并在终端上显示与它等值的二进制数。 6.试编写一段程序,从键盘接收一个0-65535间的十进制无符号数,并在终端上显示与它等值的二进制数。 7.试编写一段程序,从键盘接收一个-32768-32767间的十进制有符号数,并在终端上显示与它等值的二进制数。 8.编写一个程序,从键盘输入一个0~65535之间的10进制无符号数,然后以16进制

汇编语言基础练习题目

、填空 1. 在8086/8088的计算机中,存储单元的20位物理地址由两部分组成,即16 位的 段地址 和16位的 偏移地址,物理地址=段地址X 10H+偏移量。 2. 段的起始地址必须是某小段的首地址,它能被 10H 整除。 3. 已知01020H 字单元的内容为6A58H 请分别写出它的两个字节单元的地址和 内容: (01020H =58H, ( 01021H =6AH 4. 指令执行后,若标志寄存器的ZF=0,则表示结果不为0;若SF=0,则表示结 果的符号是正号,即结果为正数。 5. 控制器从存储器取出一条指令后,指令指针寄存器IP 的内容是 将要执行的下 一条指令开始的偏移地址。 6. 段地址和偏移地址为1000: 127B 的存储单元的物理地址是1127BH 解:由物理地址=段地址X 10H+偏移量的公式可得 物理地址=1000HX 10H+127BH=10000H+127BH=1127BH 、选择 1. 与CS 寄存器组合才能形成代码段的物理地址的寄存器是 解:16K 个字单元,即为32K 个字节单元。由于2的15次方为32K,因此至 少需要15位二进制数才能表示16K 个字单元。 3. 已知一数据段的段地址是0100H,这个段的第6个字单元的物理地址是(B ) o 解:由于一个字单元占用两个字节,第一个字单元的偏移地址为 0000H,因 此第一个字单元的物理地址为 01000H 。以后每一个字单元的地址在前一个的基 C )。 A. SP 寄存器 B. BP 寄存器 C. IP 寄存器 D. BX 寄存器 2.如果存储器分段时, 的二进制数至少是( 一个段最多允许16K 个字单元,那么表示该段内偏移地址 A )o A.15 位 位 B.16 位 C.17 位 D.18 A. 01010H B. 0100AH C.01012H D.01006H

汇编语言复习题

一、单项选择题(在每小题列出的四个选项中只有一个选项是符合题目要求的,请将正确选项前的字母填在题后的括号内。每小题1分,共20分) 1、设DS=8225H,DI=3942H,指令NEG BYTE PTR [DI]操作数的物理地址是()。 A、85B92H B、86192H C、BB690H D、12169H 2、下列寄存器组中在段内寻址时可以提供偏移地址的寄存器组是()。 A、AX,BX,CX,DX B、BX,BP,SI,DI C、SP,IP,BP,DX D、CS,DS,ES,SS 3、循环指令LOOPNZ终止循环的条件是()。 A、CX=0,且ZF=0 B、CX=0,或ZF=1 C、CX≠0,且ZF=0 D、CX≠0,或ZF=1 4、对寄存器AX的内容乘以4的正确指令序列是()。 A、SHR AX,1 SHR AX,1 B、SHL AX,1 SHL,AX,1 C、ROL AX,1 ROL AX,1 D、RCR AX,1 RCR AX,1 5、执行INC指令除对于SF、ZF有影响外,还要影响的标志位是()。 A、OF,AF,PF B、OF,AF,CF C、OF,PF,CF D、AF,PF,CF 6、设DH=10H,执行NEG DH指令后,正确的结果是()。 A、DH=10H CF=1 B、DH=10H CF=0 C、DH=10H CF=0 D、DH=0F0H 7、下列传送指令中有语法错误的是()。 A、MOV CS,AX B、MOV DS,AX C、MOV SS,AX D、MOV ES,AX 8、下面指令执行后,改变AL寄存器内容的指令是()。 A、TEST AL,02H B、OR AL,AL C、CMP AL,BL D、AND AL,BL 9、执行除法指令后,影响的标志位是() A、CF,OF

汇编语言课后习题解答

第1章基础知识 检测点1.1(第9页) (1)1个CPU的寻址能力为8KB,那么它的地址总线的宽度为13位。 (2)1KB的存储器有1024个存储单元,存储单元的编号从0到1023。 (3)1KB的存储器可以存储8192(2^13)个bit,1024个Byte。 (4)1GB是1073741824(2^30)个Byte、1MB是1048576(2^20)个Byte、1KB是1024(2^10)个Byte。 (5)8080、8088、80296、80386的地址总线宽度分别为16根、20根、24根、32根,则它们的寻址能力分别为: 64(KB)、1(MB)、16(MB)、4(GB)。 (6)8080、8088、8086、80286、80386的数据总线宽度分别为8根、8根、16根、16根、32根。则它们一次可以传送的数据为: 1(B)、1(B)、2(B)、2(B)、4(B)。 (7)从内存中读取1024字节的数据,8086至少要读512次,80386至少要读256次。 (8)在存储器中,数据和程序以二进制形式存放。

(1)1KB=1024B,8KB=1024B*8=2^N,N=13。 (2)存储器的容量是以字节为最小单位来计算的,1KB=1024B。 (3)8Bit=1Byte,1024Byte=1KB(1KB=1024B=1024B*8Bit)。 (4)1GB=1073741824B(即2^30)1MB=1048576B(即2^20)1KB=1024B(即2^10)。(5)一个CPU有N根地址线,则可以说这个CPU的地址总线的宽度为N。这样的CPU 最多可以寻找2的N次方个内存单元。(一个内存单元=1Byte)。 (6)8根数据总线一次可以传送8位二进制数据(即一个字节)。 (7)8086的数据总线宽度为16根(即一次传送的数据为2B)1024B/2B=512,同理1024B/4B=256。 (8)在存储器中指令和数据没有任何区别,都是二进制信息。

汇编程序习题

汇编程序习题 1.试分析以下程序段完成什么功能? MOV CL,4 SHL DX,CL SHL AX,CL SHR BL,CL INT 3 2.写出执行以下计算的指令序列: 1)Z←W+(Z-X)2)Z←W-(X+6)-(R+10) 3)Z←(W*X)/(R+6)4)Z←((W-X)/5*Y)*2 3.求两个数56H和67H进行ADD,并求出标志OF,CF,SF,ZF的值。4.阅读程序段,回答下述问题: 1)MOV AX,4000H 2)MOV AX,5678H 3)MOV AX,1234H OV DS,AX MOV BX,99AAH MOV CX,8912H MOV BX,1238H PUSH BX CMP AX,CX MOV〔BX〕,2244H PUSH AX INT 3 MOV AL,〔BX〕 POP DX SF=?OF=?JA成立否? INT 3 POP CX AL=?存储器的物理地址=?DX=?CX=? 5.下列程序能完成什么功能? DATY1 DB 300DUP(?) DATY2 DB 100DUP(?) …… MOV CX,100 MOV BX,200 MOV SI,0 MOV DI,0 NEXT:MOV AL,DATY1〔BX〕〔SI〕 MOV DATY2〔DI〕,AL

INC SI INC DI LOOP NEXT 6.下列指令哪些是错误的?并简述之。 1)MOV 15,BX 2)CMP OP1,OP2(假定OP1,OP2是用DB定义的变量) 3)CMP AX,OP1 4)CMP OP1,25H 5)MOV DS,CS 7.下列程序段执行后,BX的值是什么? MOV CL,3 MOV BX,0B8H ROL BX,1 ROR BX,CL 8.编写一个程序段,将内存200H单元开始的256个单元的内容,取绝对值后传送到400H开始的256个单元中。 9.求出下列各数与62A0H之和,并根据结果确定SF,ZF,CF,OF的值。 1)1234H 2)4321H 3)CFA0H 4)9D60H 10.求出下列各数与4AE0H之差,并根据结果确定SF,ZF,CF,OF的值。 1)1234H 2)5D80H 3)9090H 4)EA04H

汇编语言试题及参考答案

汇编语言试题及参考答案 一,填空题 1.ZF标志位是标志结果是否为零的,若结果,ZF为( 1 ),否则ZF为( 0 ).当ZF为1时,SF为( 0 ) 2.标号可以有两种类型属性.它们是( )和( ) 3.8位无符号整数的表示范围为0--255,写成16进制形式为( ),8位有符号整数的表示范围为-128--+127,写成16进制形式为( ) 4.伪指令DB,GROUP 和NAME 三个标号名字域必须有名字的是( ),不得有名字的是( ),可有可无名字的是( ). 5.循环程序通常由( )( )( )和循环结果外理四部分构成 6.在数值不达式中,各种运算符可可混合使用,其优先次序规则*,/( )于+,-;XOR,OR( )于AND,LT( )于GT 7. 宏指令定义必须由伪指令( )开始,伪指令( )结束,两者之间的语句称为( ) 8.调用程序与子程序之间的参数传递方法有四种,即堆栈法( )( )( ) 9.分别用一条语句实现下述指明的功能 (1)栈顶内容弹出送字变量AYW( ) (2)双字变量AYD存放的地址指针送ES和SI( ) (3)变量AY2类型属性送AH( ) (4)不允许中断即关中断( ) (5)将字符串'HOW ARE YOU!'存入变量AYB( ) (6)子程序返回调用程序( ) (7)地址表达式AYY[4]的偏移地址送字变量ADDR( ) (8)AX的内容加1,要求不影响CF( ) (9)BX的内容加1,要求影响所有标志位( ) (10)若操作结果为零转向短号GOON( ) 二,单选题 1.IBM PC微机中,有符号数是用( )表示的 1.原码 2.补码 3.反码 4.BCD码 2.把汇编源程序变成代码程序的过程是( ) 1.编译 2.汇编 3.编辑 4.链接

汇编语言复习题

汇编语言复习题 第2章8086CPU寄存器的结构及使用 1.8086CPU由指令执行部件EU和总线接口部件BIU两部分组成。其中EU的功能是控制和执行指令,主要由算术逻辑部件ALU、EU控制部件、8个16位寄存器和一个标志寄存器FLAGS组成。BIU的功能是从存储器预取指令和数据,以及所有EU需要的总线操作,实现CPU与存储器和外设间信息传递。BIU由指令队列、指令指针寄存器、段寄存器、地址加器组成。 2.Intel 8086CPU共有14个16位寄存器,它们分别是通用寄存器8个即AX、BX、CX、DX、SP、BP、SI、DI,其中能用作寄存器间接寻址的寄存有BX、BP、SI和DI,控制寄存器2个即IP、PSW,段寄存器4个即DS、SS、CS和ES它们的含义分别是: 其中在编程过程中程序的段基值由汇编程序装入的段寄存器是SS和CS ,由编程者用汇编指令将段基值装入的段寄存器是DS和ES,其具体指令是MOV AX,数据段段/附加数据段名,MOV DS/ES,AX,编程人员不能用指令去取其值或给其设置给定值的寄存器是 IP ,但是可以通过某些指令的执行而自动修改其内容,如JMP NEXT指令的功能是将目的地址的偏移量送入IP。 3.PSW是程序状态字寄存器又称为标志寄存器,用来反映微处理器在程序运行时的某些状态,其中的6个状态标志位分别是OF、SF、ZF、AF、PF和CF,反映了刚执行完算术或逻辑运算指令后的某些特征。三个控制标志位是DF即方向标志、IF即中断标志位和TF陷阱标志。如两个8位的二进制数相加其状态标志位中各标志的值是多少?10110101+10011011。 4.8086CPU数据总线16根地址总线是20根能访问的最大存储空间是1MB。 第3章存储器的分段 1.在8086CPU中存储器的编址原则是按字节编址即每一个字节单元是一个存储器地址,在源程序中用常用十六进制数或符号来表示一个存储单元的地址。任何相邻的两个字节地址可以构成一个字地址,约定用较小的那个地址来表示字地址。程序员在编程时所用的地址称为逻辑地址,CPU访问的地址称为物理地址。物理地址与逻辑地址的关系是:物理地址=段基值*16+偏移地址。如有下列存储器的结构请按要求回答问题: ① 0002H的字节地址的内容是多少? ② 0002H的字地址的内容是多少? ③若该存储地址所在的数据段的段基值是0F3BH,则逻辑地址 为0004H的物理地址是多少?该物理地址的字单元内容是多少? ④物理地址是0F3B1H的字节单元内容是多少?

汇编语言课后习题答案 郑晓薇

习题一 1 分别将下列二进制数作为无符号数和带符号数转换为十进制和十六进制数 11010011,01110111,10000011,00101111 ,10101010 查看正确答案 无符号数: 11010011=211=D3H,01110111=119=77H,10000011=131=83H,00101111=47=2FH,10101010=170=AAH 带符号数:11010011= -45=D3H,01110111=+119=77H,10000011= -125=83H,00101111=+47=2FH,10101010= -86=AAH 2 十六进制运算 1A52H+4438H ,3967H-2D81H,37H×12H ,1250H×4H 查看正确答案 5E8AH,0BE6H,3DEH,4940H 3 将十进制数变为8位补码,做运算(结果用二进制、十六进制、十进制表示) 29+53,73-24,-66+82 ,-102-15 查看正确答案 00011101+00110101=01010010=52H=82 01001001+11101000=00110001=31H=49 10111110+01010010=00010000=10H=16 10011010+11110001=10001011=8BH= -117 4 用压缩BCD码计算(结果用二进制、BCD码、十进制表示) 29+53,73-24,66+18 ,132+75 查看正确答案 00101001+01010011=01111100+00000110=10000010=82H=82 01110011-00100100=01001111-00000110=01001001=49H=49 01100110+00011000=01111110+00000110=10000100=84H=84 0000000100110010+01110101=0000000110100111+00000110 =0000001000000111=0207H=207 5 符号位扩展(字节扩展为字,字扩展为双字) 20A3H,94H ,3456H ,7FH ,EC00H 查看正确答案 000020A3H,FF94H,00003456H,007FH,FFFFEC00H 6 若机器字长为16位,其无符号数表示范围是多少?带符号数表示范围是多少?分别用十进制和十六进制表示。 查看正确答案 无符号数:0~65535,0000H~FFFFH;带符号数:-32768~+32767,8000H~7FFFH 7 写出下列十六进制数所能代表的数值或编码: (1)38H (2)FFH (3)5AH (4)0DH

51汇编程序练习题1

单片机汇编程序设计练习 一、存储器之间的数据传送 1、编程实现将单片机内部RAM60H开始的连续32个单元置为FFH。 2、编程实现将内部RAM30H开始的连续16个数传送到内部RAM50H开始的连续单元中。 3、编程实现将单片机外部RAM2000H为首地址的数据块传送到单片机内部RAM30H开始的单元中,数据块的长度为32个字节。 4、编程实现将单片机内部RAM30H为首地址的数据块传送到外部RAM2000H 开始的单元中,数据块的长度存放于内部RAM的20H单元。 5、编程实现将单片机外部RAM2000H为首地址的数据块传送到单片机内部RAM30H开始的单元中,直到数据内容为0DH时停止传送。 6、编程实现将ROM1000H地址的内容传送到内部RAM的25H单元。 7、编程实现将ROM2000H开始的连续10个地址的内容传送到内部RAM的25H 开始的单元。 8、编程实现将ROM1000H开始的连续100个地址的内容传送到外部RAM2000H 开始的连续单元中。 二、查表程序设计 1、编写查表程序,要查表的数据存放在R7中,其范围为0~9。编程查其平方值,并存放于40H。 2、编写查表程序,要查表的数据存放在R7中,其范围为0~9。编程查其立方值,并存放于R6。 3、单片机外部ROM TAB1地址开始存放一组ASCII码表,试用查表方法,将R2的内容(范围为0~F)转换为与其对应 的ASCII码,并从P1口输出。 4、使用8051的P1口作为段控驱动共阳 LED数码管,硬件连接如图。 编程实现将8051 R7单元内容(在 00H-09H之间)显示在数码管上。00H-09H 的共阳字形代码如下表所示。 04H 05H 06H 07H 08H 09H

汇编语言题库

汇编语言题库 一、单项选择题 1、在下列的选项中,能够组成计算机系统的是()。 A.硬件系统和软件系统 B.CPU、存储器、输入/输出设备 C.操作系统、各种语言 D.系统软件和应用软件2、汇编语言属于()。 A.用户软件 B.系统软件 C.高级语言 D.机器语言3、汇编语言源程序经汇编程序汇编后产生的文件的扩展名是()。 A.EXE B.OBJ C.ASM D.LST 4、汇编语言的什么文件经链接(LINK)后产生可执行文件? A.ASM B.EXE C.LST D.OBJ 5、中央处理器CPU是由()组成的。 A.运算器 B.控制器 C.寄存器组 D.前三者6、IBM PC机的DOS是属于()。 A.用户软件B.系统软件C.系统硬件 D.一种语言7、汇编语言源程序是()程序。 A.不可直接执行的B.可直接执行的 C.经汇编程序汇编后就可执行的D.经连接后就可直接执行的8、8086/8088 CPU的寄存器组中,8位的寄存器共有()个。 A.4B.6C.8D.109、8086/8088 CPU的寄存器组中,16位的寄存器共有()个。 A.10B.12C.13D.1410、8086/8088 CPU执行算术运算时PSW共有()个标志位会受影响。 A.4B.5C.6D.711、在程序执行过程中,IP寄存器始终保存的是()。 A.上一条指令的首地址B.本条指令的首地址。 C.下一条指令的首地址D.需计算有效地址后才能确定地址。 12、IBM PC机的存储器可分()个段。 A.4B.256C.512D.65536 13、当使用BP作编程地址时,此时使用的是()段。 A.CSB.DSC.ESD.SS

汇编语言考试复习试题及答案

《汇编语言》考试复习题及答案 一、单项选择题(共20小题,每小题1分,共20分)在每题列出的四个备选项中只有一个是符合要求的,请将其代码填写在题后的括号内。错选、多选或未选均无分。 1.CPU要访问的某一存储单元的实际地址称() A.段地址B.偏移地址 C.物理地址D.逻辑地址 2.某存储单元的物理地址是12345H,可以作为它的段地址有()A.2345H B.12345H C.12340H D.1234H 3.执行后使BX=0的同时也使CF=0,OF=0的指令是()A.XORBX,BX B.ORBX,BX C.ANDBX,BX D.CMPBX,BX 4.循环控制指令LoopNZ/LoopNE控制循环继续执行的条件是()A.CX≠0且ZF=1B.CX≠0且ZF=0 C.CX≠0或ZF=1D.CX≠0或ZF=0 5.在执行DAA指令,当高四位BCD码校正时产生进位,如要把此进位值送入AH中,对这进位值的操作应是() A.DAA校正指令的功能已自动加在AH中 B.进位值在AF中,校正后根据AF内容再加在AH中 C.进位值在CF中,校正后根据CF内容再加在AH中

D.进位值在AL最高位上,校正后根据AL最高位内容再加在AH中6.AND,OR,XOR,NOT为四条逻辑运算指令,下面的解释正确的是()A.指令XORAX,AX执行后,AX内容不变,但设置了标志位 B.指令ORDX,1000H执行后,将DX最高位置1,其余各位置0 C.指令ANDAX,OFH执行后,分离出AL低四位 D.NOTAX,执行后,将AX清0 7.在执行下列指令时,需要使用段寄存器DS的指令是()A.STOSW B.ADDAL,CL C.NEGBX D.INCDA[BX] 8.无论BH中原有的数是奇数或偶数,若要使BH中的数一定为奇数,应执行的指令是() A.ADDBH,01H B.ORBH,01H C.XORBH,01H D.TESTBH,01H 9.完成对CL寄存器的内容乘以4的正确操作是() A.ROLCL,1B.MUL4 ROLCL,1 C.SHLCL,1D.MOVCL,2 SHLCL,1SHLCL,CL 10.下面各传送指令中,正确的是() A.MOV[DI],[SI]B.MOV[DX+DI],AL C.MOVWORDPTR[BX],0100H D.MOV AL,BX 11.汇编语言语句格式中对名字项的规定如下,请找出其中错误的说法()

汇编语言程序设计(钱晓捷)课后答案

汇编语言程序设计(第二版) 钱晓捷习题答案 第二章(01) 2.1 (1)AX=1200h (2)AX=0100h (3)AX=4C2Ah (4)AX=3412h (5)AX=4C2Ah (6)AX=7856h (7)AX=65B7h 2.2(1) 两操作数类型不匹配 (2) IP指令指针禁止用户访问 (3) 立即数不允许传给段寄存器 (4) 段寄存器之间不允许传送 (5) 两操作数类型不匹配 (6) 目的操作数应为[ BP ] (7) 源操作数应为[BX+DI] (8) 立即数不能作目的操作数 2.3 lea bx,table ;获取table的首地址,BX=200H mov al,8 ;传送欲转换的数字,AL=8 xlat ;转换为格雷码,AL=12H 2.4 堆栈是一种按“先进后出”原则存取数据的存储区域。 堆栈的两种基本操作是压栈和出栈,对应的指令是PUSH和POP。 2.5 mov ax,8057h push ax mov ax,0f79h push ax pop bx ;bx=0f79h pop [bx] ;DS:[0f79h]=8057h 2.6 AL=89h CF ZF SF OF PF AL=12h 1 0 0 1 1 AL=0afh 0 0 1 0 1 AL=0afh 1 0 1 0 1 AL=00h 0 1 0 0 1 AL=0ffh 0 0 1 0 1 AL=00h 0 1 0 0 1 2.7 W=X+Y+24-Z

2.8 (1)ADD DX,BX (2)ADD AL,[BX+SI] (3)ADD [BX+0B2H],CX (4)ADD WORD PTR [0520H],3412H (5)ADD AL,0A0H 2.9;为了避免与操作数地址混淆,将题中X,Y,Z,V 字操作数改为A,B,C,D mov ax,X ;ax=A imul Y ;dx,ax = A*B (将操作数看作符号数,以下同) mov cx,ax mov bx,dx ;bx,ax <-- dx,ax =A*B mov ax,Z ;ax = C cwd ;dx,ax =C (扩展符号后为双字) add cx,ax adc bx,dx ;bx,cx <-- bx,cx+dx,ax=A*B+C sub cx,540 sbb bx,0 ;bx,cx<-- A*B+C-540 mov ax, V ;ax= D cwd ;dx,ax= D (扩展符号后为双字) sub ax, cx sbb dx, bx ;dx,ax = dx,ax - bx,cx = D-(A*B+C-540) idiv X ;运算结果:[D-(A*B+C-540h)]/A ;ax存商,dx存余数 2.10;(1)xchg的操作数不能是立即数 (2不能对CS直接赋值 (3)两个操作数不能都是存储单元 (4)堆栈的操作数不能是字节量 (5)adc的操作数不能是段寄存器 (6)没有确定是字节还是字操作 (7)in不支持超过FFH的直接寻址 (8)out只能以AL/AX为源操作数 第二章(02) 2.11; 指令AX的值CF OF SF ZF PF Mov ax,1407h1470h----- And ax,ax1470h00000 Or ax,ax1470h00000 Xor ax,ax000011 Not ax0ffffh----- Test ax,0f0f0h0ffffh00101 注意: 1. mov, not指令不影响标志位 2. 其他逻辑指令使CF=OF=0, 根据结果影响其他标志位。

汇编语言程序例题0001

【例】试编写一程序计算以下表达式的值。 w = (v- (x * y + z -540 )) /x 式中x、y、z、v均为有符号字数据。 设x、y、z、v的值存放在字变量X、Y、Z、V中,结果存放在双字变量W之中,程序的流程图如图所示。 DATA SEGMENT X DW 200 Y DW 100 Z DW 3000 V DW 10000 W DW 2 DUP (?) DATA ENDS STACK SEGMENT STACK DB 200 DUP (0) STACK ENDS CODESEGMENT ASSUME DS DATA CS: CODE SS: STACK START MOV AX DATA MOV DS AX ; DATA>AX MOV AX X IMUL Y ; (X) * (DX AX MOV CX AX

MOV BX,DX ;(DX AX) T BX : CX ) MOV AX,Z CWD ; (Z)符号扩展 ADD CX,AX ADC BX,DX ; ( BX: CX)+( DX:AX)BX: CX) SUB CX,540 SBB BX,0 ;( BX:CX) - 5 40~BX : CX) MOV AX,V CWD ; (V)符号扩展 SUB AX,CX SBB DX, BX ;( DX: AX)-((BX CX DX: AX) IDIV X ;( DX:AX)/X MOV W,AX ;商5 MOV W+2 DX ;余数D?W+2 MOV AH,4CH INT 21H CODEENDS ;退出DOS 状态 END START 【例】已知某班学生的英语成绩按学号(从 1 开始)从小到大的顺序排列在要查的学 生的学号放在变量NO中,查表结果放在变量ENGLISH中。编写程序如下: STACK SEGMENT STACK DB 200 DUP(0) STACK ENDS DATA SEGMENT TAB DB 80 ,85,86,71,79,96 DB 83 ,56,32,66,78,84 NO DB 10 ENGLIST DB ? DATA ENDS CODE SEGMENT ASSUME DS: DATA,SS: STACK,CS: CODE BEGIN: MOV AX,DATA MOV DS,AX LEA BX,TAB MOV AL,NO DEL AL XLAT TAB MOV ENGLIS,H AL MOV AH,4CH INT 21H CODEENDS TAB表中,

汇编题库重点复习题

1.已知X=76,则[X]补=_______。 A.76H B. 4CH C. 0B4H D. 0CCH 2.已知[X]补=80H,则X =_______。 A.80H B.0 C. 0FFH D. -80H 3.已知[X]补=80H,则[X]补/2=_______。 A.0CCH B.4CH C. 49H D. 31H 4.已知X=78,Y=-83,则[X+Y]补=_______。 A.0F5H B.0A1H C. 0FBH D. 65H 5.将124转换成十六进制的结果是_______。 A.7CH B.7DH C. 7EH D. 7BH 6.将93H看成一个压缩的BCD码,其结果是_______。 A.10010101 B.10010011 C. 10000011 D. 10000001 7.45转换成二进制数是_______。 A.10101101 B.00111101 C. 00101101 D. 10011101 8.6CH 转换成十进制数是_______。 A.118 B.108 C. 48 D. 68 9.将93H扩展为字的结果是_______。 A.FF93H B.0093H C. 1193H D. 1093H 10.56的压缩BCD码是_______。 A.38H B. 56H C. 0506H D. 3536H 11.ASCII中的47H表示字符的是_______。 A.“7” B. “G” C. “g” D. “E” 12.十进行数-1的8位二进制数补码是_______。 A.11111110 B. 11110000 C. 11111111 D. 10001111 13.下列为补码表示,其中真值最大的数是_______。 A.10001000 B. 11111111 C. 00000000 D. 00000001 14.十六进制数88H,可表示成下面几种形式,请找出错误的表示_______。 A.无符号十进制数136 B. 1带符号十进制数-120D C. 压缩BCD码十进制数88 D. 8位二进制数-8的补码 15.计算机对字符、符号采用统一的二进制编码。其编码采用的是_______。 A.BCD码 B. 二进制码 C. ASCII D. 十六进制码第二章 16.在微机中分析并控制指令执行的部件是_______。 A.寄存器 B. 数据寄存器 C. CPU D. EU 17.在计算机的CPU中执行算术逻辑运算的部件是_______。 A.ALU B. PC C. AL D. AR 18.执行指令PUSH CX后堆栈指针SP自动_______。 A.+2 B. +1 C. —2 D. —1 19.在标志寄存器中表示溢出的是_______。 A.AF B. CF C. OF D. SF 20.对汇编语言源程序进行翻译的是程序是_______。 A.连接程序 B. 汇编程序 C. 编译程序 D. 目标程序

(完整版)汇编语言复习题

汇编语言程序设计复习题 一、单项选择题 1.假设(AL)=0FFH依次执行ADD AL,0FH指令后,标志位ZF和SF的状态分别为(A ) A. 0和0 B. 0和1 C. 1和0 D. 1和1 2.假设V AR为变量,指令MOV BX,V AR 的寻址方式是( A ) A.直接寻址B.间接寻址C.立即寻址D.存储器寻址 3.下列指令中,不影响标志位的是 ( C ) A.SUB BX,BX B.ROR AL,1 C.JNC Lable D.AND AL,CL 4.假定(DS)=4000H,(DI)=0100H,(40100H)=55H,(40101H)=0AAH,试问执行指令MOV BX, [DI]后,(BX)= ( C ) A.0100H B.55AAH C.AA55H D.4100H 5.执行下列哪一条指令后,就能用条件转移指令判断AL和BL寄存器中的最高位是否相同?(D ) A. TEST AL BL B. CMP AL BL C. AND AL BL D. XOR AL BL 6.堆栈中当前出栈的存储单元地址是 (A ) A. SS*10H+SP B. SS*10H+BP C. SS*10+SP D. SS*10+BP 7.已知V AR DW l,2,$+2,5,6 若汇编时V AR分配的偏移地址是0010H,则汇编后0014H单元的内容是( D ) A.6H B.14H C.5H D.16H 8.循环控制指令REPNZ继续执行循环的条件是(B ) A. CX≠0且ZF=1 B. CX≠0且ZF=0 C. CX≠0或ZF=1 D. CX≠0或ZF=0 9.设NUM=11011011B,指令“MOV AL,NUM SHL 3”执行后AL中的值是(B ) A.11011011000B B.11011000B C.00011011B D.00011011011B 10.下面XCHG指令语句中,语法正确的是(B) A. XCHG AX,DS B. XCHG BL,[BX] C. XCHG AL,OFH D. XCHG [SI],[DI] 11.算术右移SAR和逻辑右移SHR两条指令执行后结果完全相同的情况是( A ) A。目的操作数最高位是0 B.目的操作数最高位是1 C.目的操作数为任何情况D.无论什么情况都不可能相同 12.设AL=04H,BL=0F8H,执行IMUL BL 指令后,结果是(D) A.AX=0032H B.AX=00EOH C.AX=03EOH D.AX=OFFEOH 13.指令的操作数中,允许出现表达式,例如BUFl与BUF2均为变量名,下面指令中语法正确的是( D ) A.MOV AX,BUF1*BUF2 B.MOV AX,BUF1/BUF2 C.MOV AX,BUF1+ES:BUF2 D.MOV AX,BUF2-BUF1 14.下面指令中,操作数的寻址方式为寄存 器间接寻址的指令是( C) A.INC WORD PTR [BX+S1] B.INC CX,[SI+COUNT] C.NEG BYTE PTR [BX] D.ADD AX,B 15.NUM EQU 80H DA DB 34H AND DA,NUM 上述语句执行后,DA中的内容是 ( D ) A,0B4H B;80H C,34H D.0 16.在同一程序段中,定义有下面的伪指令, 使用正确的是(B ) A.PORT1 EQUAL PORTl EQU 2000H B.PORT2 = 3500H AND 0FFH C.PORT3 DD ‘ABCD’ D.PORT4 PROC ...RET ENDP 17.语句DA1 DB 2 DUP(3,5,7)汇编后, 该语句可等同于的语句是(D ) A.DA1 DB 3,5,7 B.DA1 DB 2,3,5,7 C.DA1 DB 3,5,7,2 D.DA1 DB 3,5,7,3,5,7 18.MOV AL,80H MOV CL,2 SAR AL,CL 上述指令执行后,结果是(D ) A.AL=40H B.AL=20H C.AL=0COH D.AL=0E0H 19.下面是实现将AL内容加1的压缩型BCD 码加法程序段,其中错误的指令序列是(A ) A.INC AL B.ADD AL,1 C.ADD AL,1 D.STC DAA DAA AAA DAA 20.DABY1 DB 12H,34H,56H,78H DB $-DABY1 DABY2 DB 8 DUP(1,2,3) ... MOV DL,SIZE DABY2 ADD DL,DABYl+2 上述指令序列执行后,DL的内容是 ( C ) A.3CH B.80H C.5EH D.1AH 21、下列寄存器组中在存储器操作数寻址时可 用于提供偏移地址的是(D) A、AX,BX,CX,DX B、SP,BP,SI,DI C、CS,ES,DS,SS D、BX,BP,SI,DI 22、执行NEG指令时,要设置标志位CF。设 置CF的正确说法是(C) A、对正数求补时,CF置0 C、对全0数据求补时,CF置0 23、要使BL中的低四位变反,高四位不变, 应执行指令(D) A、NOT BL C、AND BL,0FH 24、在8086/8088的立即数寻址方式中,对寄 存器的使用下列说法正确的是(D) A、使用AX,BX,CX,DX C、使用任一个通用寄存器 25、MOV AL,-1 NEG AL XOR AL,65 上述指令执行后,AL的值是(B) A、01H C、61H 26、在查错程序DEBUG中,为查看或修改内 存单元的内容,使用的命令是(A) A、D或E C、R 或E 27、指令MOV CL,55H XOR 0F0H执行后 CL中的值是(C) A、05H C、0A5H 28、对CS段寄存器赋段地址的方法是(B) A、MOV AX,CODE MOV CS,AX C、END 起始地址 29、X DW 1234H,0A9BH Y DB 7EH,8DH ┇ MOV BH,TYPE X MOV BL,TYPE Y 执行后BX的内容是(D ) A、0102H C、1234H 30、条件转移指令JBE产生转移的条件是(A) A、CF=1 OR ZF=1 C、CF=1 OR ZF=0 31、某存储单元的段地址是0AB90H,偏移地 址是1234H,该存储单元的物理地址是(B) A、0BDC4H C、0AD134H 32、设DF=1,每次执行CMPSW指令时,SI 和DI均要分别(B) A、减1 C、加1 33、设(AL)=07H,要使(AL)=-07H应执 行的指令是(C) A、OR AL,80H C、NEG AL 34、下列指令执行时操作数在数据段的是(D) A、MOV AX,32768H C、NEG BX 35、设SP=4AH,执行段内返回指令RET 4后, SP的值是(A) A、50H 1

汇编语言课后习题答案

2.1已知DS=2000H、BX=0100H、SI=0002H,存储单元[20100H]~[20103H]依次存放12 34 56 78H,[21200H]~[21203H]依次存放2A 4C B7 65H,说明下列每条指令执行完后AX寄存器的内容。 (1)mov ax,1200h (2)mov ax,bx (3)mov ax,[1200h] (4)mov ax,[bx] (5)mov ax,[bx+1100h] (6)mov ax,[bx+si] (7)mov ax,[bx][si+1100h] 〔解答〕 (1)AX=1200H (2)AX=0100H (3)AX=4C2AH ;偏移地址=bx=0100h (4)AX=3412H ;偏移地址=bx=0100h (5)AX=4C2AH ;偏移地址=bx+1100h=1200h (6)AX=7856H ;偏移地址=bx+si=0100h+0002h=0102h (7)AX=65B7H ;偏移地址=bx+si+1100h=0100h+0002h+1100h=1202h 〔习题2.2〕指出下列指令的错误 (1)mov cx,dl (2)mov ip,ax (3)mov es,1234h (4)mov es,ds (5)mov al,300 (6)mov [sp],ax (7)mov ax,bx+di

(8)mov 20h,ah 〔解答〕 (1)两操作数类型不匹配 (2)IP指令指针禁止用户访问 (3)立即数不允许传给段寄存器 (4)段寄存器之间不允许传送 (5)两操作数类型不匹配 (6)目的操作数应为[ SI ] (7)源操作数应为[BX+DI] (8)立即数不能作目的操作数 〔习题2.5〕已知SS = 2200H、SP = 00B0H,画图说明执行下面指令序列时,堆栈区和SP的内容如何变化?mov ax,8057h push ax mov ax,0f79h push ax pop bx pop [bx] 〔解答〕 mov ax,8057h push ax mov ax,0f79h push ax pop bx ;bx=0f79h pop [bx] ;DS:[0f79h]=8057h

汇编语言程序设计练习题

汇编语言程序设计练习题 阅读程序并完成填空: 1.1.MOV BL,85H MOV AL,17H ADD AL,BL AL=?,BL=?,CF=? 2.2.MOV AX,BX NOT AX ADD AX,BX INC AX AX=?,CF=? 3.3.MOV AX,0FF60H STC MOV DX,96 XOR DH,0FFH SBB AX,DX AX=?,CF=? 4.4.MOV BX,0FFFEH MOV CL,2 SAR BX,CL 5.5.MOV BX,0FFH AND BX,0FFFH OR BX,0F0FH XOR BX,00FFH 上述程序段运行后,BX=?,CF=? 6.6.CMP AX,BX JGE NEXT XCHG AX,BX NEXT:CMP AX,CX JGE DONE XCHG AX,CX DONE:。。。。。 试回答: (1)(1)上述程序段执行后,原有AX、BX、CX中最大数存放在哪个寄存器中? (2)(2)这3个数是带符号数还是无符号数?

7.7.在数据段ADDR1地址处有200个字节,要传送到数据段ADDR2处。 MOV AX,SEG ADDR1 MOV DS,AX MOV ES,------- MOV SI,------- MOV DI,OFFSET ADDR2 MOV-----,200 CLD REP--------- 8.8.ADDR1开始的单元中连续存放两个双字数据,将其求和存放在ADDR2开始的单元。 MOV CX,2 XOR BX,BX CLC NEXT:MOV AX,[ADDR1+BX] ADC AX,------- MOV[ADDR2+BX],AX ADD--------,2 ---------NEXT 9.9.设初值AX=1234H,BX=5678H,DX=0ABCDH,则执行下面一段程序后AX=------,BX=----,DX=--------。 MOV CL,4 SHL DX,CL MOV BL,AH SHL AX,CL SHR BL,CL OR DL,BL 10.10.设有一个首地址为ARRAY有N个字数据的数组,要求求出该数组之和,并把结果存入TOTAL地址中,有关程序如下:MOV CX,------ MOV AX,0 MOV SI,0 START:ADD AX,-----

相关主题
文本预览
相关文档 最新文档