文档库 最新最全的文档下载
当前位置:文档库 › 微机原理与汇编语言

微机原理与汇编语言

微机原理与汇编语言
微机原理与汇编语言

微机原理与汇编语言复习题及参考答案

一、选择题:

1. 设AL=0A8H,CX=2,CF=1,执行RCL AL,CL指令后,AL中的值为()

A. 51H

B. A3H

C. 47H

D. 0C5H

2. 下述指令的执行结果是()MOV AL,0C2H

AND AL,0F0H

A.AL=40H

B.AL=20H

C.AL=0C0H

D.AL=0E0H

3. 完成对CL寄存器的内容乘以4的正确操作是()

A.ROL CL,1

B.MUL 4

C.SHL CL,1

D.MOV CL,2

ROL CL,1 SHL CL,1 SHL CL,CL

4. 无论BH中原有的数是奇数或偶数,若要使BH中的数一定为奇数,应执行的指()

A. ADD BH,01H

B. OR BH,01H

C. XOR BH,01H

D. TEST BH,01H

5. 假设(AL)= 37H,(BL)= 95H,执行指令IMUL BL后(AX)= ()

A. 0E903H

B. 2003H

C. 0DBBH

D. 2008H

6. 下面的数据传送指令中,错误的操作是()

A. MOV SS:[BX+DI],1000H

B. MOV DX,1000H

C. MOV WORD PTR[BX],1000H

D. MOV DS,2000H

7. CPU要访问的某一存储单元的实际地址称()

A.段地址B.偏移地址C.物理地址D.逻辑地址

8. 某存储单元的物理地址是12345H,可以作为它的段地址有()A.2345H B.12345H C.12340H D.1234H

9. 计算机能直接识别的的语言()A.汇编语言 B.机器语言C.高级语言D.低级语言

10. 下列指令中操作数在代码段中的是()A.MOV AL,25H B.ADD AH,BL C.INC DS:[25] D.CMP AL,BL

11.直接、间接、立即三种寻址方式指令的执行速度,由决至慢的排序为()A.直接、立即、间接 B.直接、间接、立即

C.立即、直接、间接 D.不一定

12.若栈顶的物理地址是2010011,当执行完指令CALL AX后,栈顶的物理地址是()A.2010211 B.2010111 C.200FFH D.200FEH

13.当执行完下列指令序列后,标志位CF和OF的值是()

MOV AX,OC126H

MOV BX,5AB7H

SUB AX,BX

A.0,0 B.0,1 C.1,0 D.1,1

14. JMP BX的目标地址偏移量是(D)。

A.SI的内容 B.SI所指向的内存字单元之内容

C.IP+SI的内容 D.IP+[SI]

15.指令MOV AX,10[BX]的源操作数的寻址方式是()

A.基址寻址 B.寄存器寻址 MOV AX,BX

C.变址寻址 AX【BX+DI】(只能用BX,BP;SI和DI) D.寄存器相对寻址

16.指出下列哪个数据在汇编语言中是非法的。()A.19BH+25D B.25+AL C.108-102Q D.101B*OABH

17.用来存放即将执行的指令的偏移地址的寄存器是()A.SP B.IP C.BP D.CS

18.源变址寄存器是()

A.SI B.DI C.SP D.BX

19.设SP=1200H,执行POP AX后,SP中的内容为()A.SP=1112H B.SP=11OEH C.SP=1111H D.SP=11OFH 20.数字6704不可能是()A.六进制数 B.十进制数 C.十二进制数 D.十六进制数21.下面四个寄存器中,不能用于间接寻址的寄存器是()A.BX B.AX C.BP D.DI

22.若(BX)=OCA8H,则执行指令MOV CL,8

ROR BX,CL后,(BX)=()

A.OCA8H B.8ACOH C.OA80CH D.OA8COH

23.下面数据传送指令中,正确的是()A.MOV DS,ES B.MOV AL,WORD PTR [BX+DI]

C.MOV AL,BYTE PTR [SI+DI] D.MOV CX,[SI]

24.下列哪一种寻址方式最快?()A.立即寻址 B.直接寻址 C.寄存器寻址 D.寄存器间接寻址

25.寄存器间接寻址中,操作数在()A.通用寄存器 B.堆栈 C.主存单元 D.段寄存器

26.在顺序结构的流程图中,不包含有()A.起始框 B.终止框 C.判断框 D.处理框

27.以8086/8088为CPU的微机内存最大容量为()

A.4MB B.1MB C.640KB D.64KB

28.与lA.5H不等的数据是()A.26.3125D B.11010.0101B C.32.5Q D.10110.0100B

29.8位二进制补码表示的整数数据范围是()

A.-128~127 B.-127~127 C.-128~128 D.-127~128

30.下列四个寄存器中,不允许用传送指令赋值的寄存器是()

A.CS B.DS C.ES D.SS

31.指令MOV 100[SI][BP],AX的目的操作数的隐含段为()

A.数据段 B.堆栈段 C.代码段 D.附加段

32.运算型指令的寻址和转移型指令的寻址,其不同点在于()

A.前者取操作数,后者决定程序的转移地址

B.后者取操作数,前者决定程序的转移地址

C.两者都是取操作数

D.两者都是决定程序的转移地址

33.设AL=0A8H,CX=2,CF=1,执行RCL AL,CL指令后,AL= ()

A.51H B.A3H C.47H D.0C5H

34.目的变址寄存器是()

A.SI B.DI C.SP D.BX

35.下列常用寻址方式中,哪种属于立即寻址 ( ) A.MOV AX,ES:[2000H] B.MOV [BX],AX

C.MOV AX,2000H D.MOV AX,[BX+3AH]

36.设SP=1110H,执行PUSH AX后,SP中的内容为()

A.SP=1112H B.SP=110EH C.SP=I111H D.SP=110FH

37.下列指令中错误的指令为()A.MOV AX,CS B.MOV DS,1500H C.MOV SI,BX D.MOV [2000H],BL 38.语句DA1 DB 2 DUP(3,5),7 汇编后,与该语句功能等同的语句是()A.DA1 DB 3,5,7 B.DA1 DB 2,3,5,7

C.DA1 DB 3,5,3,5,7 D.DA1 DB 3,5,7,3,5,7

39.下面四个寄存器中,用来作为I/O端口间接寻址的寄存器是()

A.BX B.DX C.BP D.DI

40.下列哪一种寻址方式最快?()

A.立即寻址 B.直接寻址 C.寄存器寻址 D.寄存器间接寻址41.在串处理指令REPNZ CMPSB表示在()

A.当(CX)不等于0且ZF等于1的情况下,重复执行串搜索

B.当(CX)不等于0且ZF等于0的情况下,重复执行串搜索

C.当(CX)不等于0且ZF等于1的情况下,重复执行串比较

D.当(CX)不等于0且ZF等于0的情况下,重复执行串比较

42. 若(DX)=0A74CH,(CL)=5,则指令SAR DX,CL执行后,(DX)= ()

A.053AH B.653AH

C.0FD3AH D.740AH

43.完成将有符号数BX的内容乘以2的正确指令是()

A.SHR BX,1 B.SAR BX,1

C.SAL BX,1 D.RCR BX,1

44.指令LOOPNZ的循环执行条件是()

A.CX ≠0且ZF=0 B.CX ≠0或ZF=0

C.CX ≠0且ZF=1 D.CX ≠0或ZF=1

45.下列寄存器中不能作为间址寄存器的是()

A.SI B.DI C.CX D.BX

46.JMP WORD PTR[BX]转移的目标地址是()

A.BX中的内容 B.SP+BX之和

C.IP+[BX]之和 D.BX指示的内存单元之内容

二、填空题:

1. 计算机中的CPU由和组成。

2. (51

3.85)10 = ( )16 ; (105.3)8 = ( ____ )10 。

3. 假定机器的字长为8位,且最高位为符号位,则(-127)10的原码用8位二进数表示为,其补码用8位二进数可表示为。

4. I/O端口有两种编址方式,分别是和。

5. 8086/8088的中断系统能够处理 _256_ 个不同的中断源,并为每一个中断安排一个编号,称为中断类型。每种中断类型对应的中断服务程序的入口地址称为。

6. 循环结构的程序主要由 ____、循环体、 _____ 和循环控制部分组成。

7. 若DS=0F3EH,SI=2000H,COUNT=0A8H,指令MOV AX,(SI+COUNT)中,源操作数的有效地址EA 为__________,其物理地址为__________。

8. 当标志位__________=1时表示无符号数运算产生溢出,而当标志位__________=1是表示带符号数运算产生溢出。

9. 将十进制数513.85转换成二进制数、八进制数、十六进制数和BCD码分别可表示为__________、__________、__________、__________。

10. 十进制数52的原码、反码、补码(采用8位二进制,最高位为符号位)分别可表示为_________、__________、__________。

11.已知某个数的补码为9DH,则其真值为__________。

12.以下宏定义的功能是将一位十六进制数转换为ASCII码,请在空白处填入恰当内容,使程序完整。

HEXTOA __________

AND AL,0FH

CMP AL, __________

JNA HEXTOA1

ADD AL,7H

HEXTOA1: ADD AL, __________

ENDM

13.地址2000H: 0480H,其物理地址是__________,段地址是__________,偏移量是__________。

14. 225D= __________B= __________H。

15.已知[X]补=11010101,则X= __________D。

16.执行部件EU的主要功能是:____________________和____________________。

17. 8086 CPU在取指令时,会选取段寄存器__________的值作为段基值,再加上由__________提供的偏移地址形成20位的物理地址。

18. 8086最多可处理__________种中断,对每一个中断都设置一个__________。

19.8086 CPU有两种外部中断请求线,它们分别是__________和__________。

20.CPU与外设之间的数据传送方式有__________、__________、__________和DMA方式传送。21. 冯·诺依曼型的计算机制结构由__________、__________、__________、__________和__________五大部分组成。

22. 101011.101B = __________D =__________O = __________H。

23.数字9的ASCII码为__________。

24. I/O端口有_________和_________两种编址方式,8086的最大I/O寻址空间为_________。25.若一个程序段开始执行之前,(CS)=97F0H,(IP)=1B40H,该程序段启动执行指令的实际地址是__________。

26. 6AB.24H = __________B = __________O。

27. 数字“0”和字母“K”的对应的ASCII码分别为__________和__________。

28.十进制数-26的原码、反码、补码(采用8位二进制,最高位为符号位)分别为__________、__________、__________;已知一个数的补码为B2H,其真值为__________。

29.汇编语句中,语句标号具备的三种属性分别是__________、__________、__________;变量具备的三种属性分别是__________、__________、__________。

30.8086CPU的数据总线为_________位,地址总线为_________位,最大的存储空间是_________。

31. 8086CPU的标志寄存器共有9个有效标志位,其中有6个状态标志位,分别是_________、

__________、_________、__________、_________、__________。

32.已知X=-1011011B,则X的反码为_________,X的补码为_________。

33. 8086CPU在取指令时,会选取段寄存器__________的值作为段基值,再加上由__________提供的偏移地址形成20位的物理地址。

三、判断题:

1.奇偶标志位PF,当运算结果的低8位中有偶数个1时,被置为0。()

2. CS, DS, ES和SS段都可以存放指令代码。()

3.MOV SI,[SI] ()

4.MOV [DI],[SI] ()

5.两数相等时转移可用JZ指令。()

6.OUT [BX],AL ()

7.当IF=0时,CPU不能响应NMI中断。()

8.把若干个模块连接起来成为可执行文件的系统程序是汇编程序。 ( )

9.使汇编程序执行某种操作的命令是宏指令。 ( )

10.串操作指令中,目的操作数的段地址一定在DS寄存器中。 ( ) 11.在汇编语句AGAIN: INC SI中的AGAIN 称为标号。 ( )

12.MOV BH,1000[SI],该指令中源操作数采用的寻址方式是寄存器间接寻址。( ) 13.OR AL,AL 是逻辑或操作指令。 ( ) 14.DOS 系统功能调用中,显示单个字符的系统调用号是01H。 ( )

15.使计算机执行某种操作的命令是伪指令。 ( )

四、改错题:

1.下述程序执行后,应将LIST数组中的最大值存入MAX单元,数组元素为无符号字数据,数据个数在CNT单元中。现已知程序有错,请改正,使之完成预定功能。

1)DSEG SEGMENT

2)LIST DW 1,200,30,400,0,7,4000

3) CNT DB 7

4) MAX DW?

5) DSEG ENDS

6) CSEG SEGMENT

7) ASSUME DS:DSEGDS:CODE

8) FMAX: MOV DX,DSEG

9) MOV DS,AX

10) LEA SI,LIST

11) MOV CX,CNT

12) CLD

13) LODSW

14) DEC CX

15) CMP AL,[SI]

16) JLE SMALL

17) LODS W

18) SMALL: INC SI

19) INC SI

20) DEC CX

21) LOOP AGAIN

22) MOV MAX,SI

23) MOV AL,4CH

24) INT 21H

25) CSEG END

26) END START

2.下面的程序是将内存单元一字节数据乘以10放回单元的程序,找出错误并改正。DATA SEGMENT

DA DW 34

DATA ENDS

CODE SEGMENT

ASSUME CS:CODE,DS:DATA

START: MOV AX,DATA

MOV DS,AX

MOV SI,OFFSET DA

MOV AL,[SI]

MUL 10

MOV [SI],AX

MOV AH,4CH

INT 21H

CODE ENDS

END START

五、简答题:

1. 80386/80486有几种工作模式?各有什么特点?

2.假定一个名为MAINPRO的程序要调用子程序SUBPRO,试问:

(1)MAINPRO中的什么指令申明汇编程序SUBPRO是在外部定义的?

(2)SUBPRO怎么知道MAINPRO要调用它?

3.现有(DS)=2000H,(BX)=O100H,(SI)=0002H,(20100H)=12H,(2010H)=34H,(20102H)=56H,(20103H)=78H,(21200H)=2AH,(21201H)=4CH,(21202H)=B7H,(21203H)=65H,试说明下列指令执行后,AX寄存器中的内容。

(1)MOV AX,[1200H] (2)MOV AX,[BX]

(3)MOV AX,1100H[BX] (4)MOV AX,[BX+SI]

(5)MOV AX,[1100H+BX+SI]

4.汇编语言源程序的语句类型有哪几种?各自的作用和使用规则是什么?

5.一个汇编源程序应该由哪些逻辑段组成?各段如何定义?各段的作用和使用注意事项是什么?

6.什么是微型计算机的系统总线?定性说明微处理器三大总线的作用。

六、程序分析题:

1.试分析下列程序段,如果AX和BX的内容分别给出如下5种情况,问程序分别转向何处?

(1) AX = 1478H, BX = 80DCH

(2) AX = 0B568H, BX = 54B5H

(3) AX = 42C8H, BX = 608DH

(4) AX = 0D023H, BX = 9FD0H

(5) AX = 94B7H, BX = 0B568H

ADD AX,BX

JNO L1

JNC L2

SUB AX,BX

JNC L3

JNO L4

JMP L5

2.已知数据段中定义

DAT1DB 12H,34H,56H,78H

MOVCX,0

MOVAX,WORDPTRDAT1

MOVCL,DAT1+3

当程序段执行完后AX=________,CX=________。

3.执行完程序后,回答指定的问题。

BLOCK DB 20H,1FH,08H,81H,OFFH…

RESULT DB?

START: LEA SI,BLOCK

MOV CH,O

MOV CL,[SI]

DEC CX

INC SI

MOV AL,[SI]

LOP1: CMP AL,[SI+1]

JLE NEXT

MOV AL,[SI+1]

NEXT: INC SI

LOOP LOP1

MOV RESULT,AL

HLT

问:(1)该程序的功能是();

(2)该程序的循环次数是()。

4. 分析下列程序,回答问题:

(1)该程序完成什么功能?

(2)程序中的INC SI可否用指令ADD SI,1代替,为什么?(3)程序中的指令LEA SI,DATAI可用指令()代替。(4) CLC指令的目的是()。

DATA SEGMENT

DATAI DB 85H,27H,4AH

DATA2 DB 93H,87H,65H

LEGH DW 3

SUM DB 0,0,0

DATA ENDS

CODE SEGMENT

ASSUME CS:CODE,DS:DATA

START: MOV AX,DATA

MOV DS,AX

LEA SI,DATA1

LEA BX,DATA2

LEA DI,SUM

MOV CX,LEGH

CLC

AGAIN: MOV AL,[SI]

ADC AL,[BX]

MOV [DI],AL

INC SI

INC BX

INC DI

LOOP AGAIN

MOV AH,4CH

1NT 21H

CODE ENDS

END START

5.执行完程序后,回答指定的问题。

MOV AX,200H

MOV BX,500H

MOV [BX+1OH],30H

ADD AX,[BX+1OH]

LEA SI,[BX+lOH]

MOV BX,AX

问:程序段执行后,SI=(),BX=()。

七、程序设计:

1.将DAT字存储单元中的16位二进制数分成四组,每组四位,然后将这四组数分别放至DAT1、DAT2、DAT3和DAT4这4个字节单元中。

2.设有10个学生的成绩分别是70,75,89,68,63,88,78,74,81和90。编制一个子程序统计60-69,70-79,80-89,90-99及100分的人数并分别存放到S6,S7,S8, S9和S10单元中。3.已知在以BUR为首地址的数据区中存放了N字节数据,编写程序完成将数据块搬至BUF2为首地址的存储区中,要求:

(1)用一般数据传送指令MOV实现;

(2)用数据串传送指令MOVSB实现;

(3)用数据串指令LODSB/STOSB实现。

4.对一组无符号数进行比较,把最大数显示在屏幕上。

5.已知两个无符号字数据X、Y分别存放在ADRX和ADRY单元,编制程序,若X是Y的倍数,则显示器上显示0,否则显示1。

参考答案

一、选择题:

1.B 2.C 3.C 4.B 5.A 6.D 7.C 8.D 9.B 10.A 11.C 12.D 13.C 14.A 15.D 16.B 17.B 18.A 19.B 20.A 21.B 22.C 23.D 24.A 25.C 26.C 27.B 28.C 29.A 30.A 31.B 32.A 33.B 34.B 35.C 36.B 37.B 38.C 39.B 40.A 41.B 42.C 43.C 44.C 45.C 46.D

二、填空题:

1.运算器控制器 2.201.D999 69.375

3.11111111 10000001 4.统一编址独立编址

5.256 中断向量 6.循环初始化部分循环参数修改部分7.20A8H 11488H 8.CF OF

9.1000000001.1011B 1001.6631O 201.D999H 10100010011.10000101B 10.00110100B 00110100B 00110100B

11.-63H

12.MACRO 9 30H

13.20480H 2000H 0480H

14.11100001 E1

15.-43H

16.执行指令产生访问存储器时所需的16位偏移地址

17.CS IP

18.256 中断码类型

19.NMI INTR(可屏蔽中断请求信号)

20.无条件传送查询方式传送中断方式传送

21.运算器控制器存储器输入设备输出设备

22.43.625 53.5 2B.A

23.39H

24.统一编址独立编址 64KB

25.99A40H

26.3253.11 1707.141

27.30H 4BH

28.10011010B 11100101B 11100110B -4EH

29.段属性偏移量属性距离属性;段属性偏移量属性类型属性

30.16 20 1MB

31.进位标志位(CF)辅助进位标志位(AF)符号标志位(SF)

零标志位(ZF)溢出标志位(OF)奇偶标志位(PF)

32.10100100B 10100101B

33.CS IP

三、判断题:

1.× 2.× 3.× 4.× 5.√ 6.× 7.× 8.×

9.× 10.× 11.√ 12.× 13.√ 14.√ 15.×

四、改错题:

1.解答:

(1)3行,数据定义伪指令DB改为DW

(2)8行,DX改为AX

(3)15行,循环入口,加标号AGAIN,即将本行改为:AGAIN:CMP AX,[SI]

(4)16行,JLE改为JAE

(5)17行,LODSW改为MOV AX,[SI]

(6)20行,去掉该行语句

(7)22行,SI改为AX

(8)23行,AL改为AH

(9)25行,END改为ENDS

(10)26行,START改为程序入口标号FMAX

2.解答:

MOV AL,[SI] 改为MOV AL,BYTE PTR [SI]

MUL 10 改为MOV BL,10

MUL BL

五、简答题:

1.答:80386/80486有实地址模式、保护模式和虚拟8086模式三种工作方式。

(1)实地址模式下的80386/80486的工作原理与8086相同,内存管理只采用分段管理方式,而不采用分页管理;内存最大空间为1MB,采用段地址寻址的存储方式,每个段最大为64KB;操作数的默认长度为16位。

(2)保护模式下,CPU实际可访问的物理空间最大为4GB,可选择使用分页结构;存储器空间用逻辑地址、线性地址和物理地址空间描述;CPU基本结构没有发生变化,指令和寻址方式依旧。在这种寻址方式中,可以对存储器实施保护功能(禁止程序非法操作)和特权级的保护功能(主要保护操作系统的数据不被应用程序修改)。

虚拟8086模式下,既有保护模式功能,又可执行8086的指令代码。

2.答:(1)只要在MAINPRO中用EXTRN说明SUBPRO即可;

(2)只要定义SUBPRO时用PUBLIC定义即可。

3.答:(1)AX=4C2AH (2)AX=3412H (3)AX=4C2AH

(4)AX=7856H (5)AX=65B7H

4.答:汇编语言源程序的语句类型通常有3种类型,分别是:指令语句、伪指令语句和宏指令语句。

(1)指令语句是能产生目标代码、CPU可以执行的能完成特定功能的语句,主要由CPU指令组成。(2)伪指令语句是种不产生目标代码的语句,在汇编过程中告诉汇编程序应如何汇编。

(3)宏指令语句是一个指令序列,汇编时凡有宏指令语句的地方都将用相应的指令序列的目标代码插入。

5.答:汇编程序是将汇编源程序自动翻译成目的程序的软件,而汇编源程序是用汇编语言编写的程序。

汇编程序的主要功能是将由汇编语言(助记符)编写的源程序翻译成用机器语言(二

进制代码)编写的目标程序;汇编源程序的作用是进行程序设计。

6.答:微型计算机的系统总线是CPU与其他部件之间传送数据、地址和控制信息的公共

通道。

根据传送内容的不同,系统总线可分成以下3种:

(1)数据总线DB(Data Bus):用于CPU与主存储器、CPU与I/O接口之间传送数据。数据总线的宽度等于计算机的字长。数据总线一般为双向总线,可以向两个方向传输数据。

(2)地址总线AB (Address Bus):用于CPU访问主存储器和外部设备时传送相关的地址。地址总线的宽度决定CPU的寻址能力。

(3)控制总线CB (Control Bus)用于传送CPU对主存储器和外部设备的控制信号。

7.答:宏与子程序两者的相同之处在于:都是用来处理在编程过程中多次使用的功能程序的方法,两者均能简化源程序。

两者的区别在于:

(1)宏调用通过宏指令名进行,汇编时,随时调用随时展开,并不简化目标程序:子程序调用是在程序执行期间执行CALL指令,代码只在目标程序中出现一次,所以也简化了目标程序。

(2)宏调用时的参数由汇编程序通过实参转换成形参的方式传递,具有很大的灵活性。宏定义中允许设置若干形式参数代替数值、指令、寄存器、各种字符串等。宏调用时可用程序所需要的实际参数来替换,使编程人员感觉非常灵活;而子程序的参数传递要麻烦得多。

(3)宏调用在汇编时完成,不需要额外的时间开销;子程序调用和子程序返回都需要时间,还涉及堆栈操作。

故若优先考虑速度,用宏指令;若优先考虑存储空间,用子程序。

六、程序分析题:

1.答:(1)L1 (2)L1 (3)L2 (4)L3 (5)L3

2.答:AX=3412H,CX=0078H

3.(1)从一组数中寻找最小数送RESULT单元。

(2)31次。

4.解答:

(1)该程序用来将存放在DATA I和DATA2开始的单元中的两个多字节数据相加,并将结果放在SUM开始的连续单元中。

(2)不可以。因为ADD指令影响进位标志位CF状态。

(3)MOV SI,OFFSET DATA1

(4)清进位,以使在数据最低字节相加时,可以用ADC指令。

5.解答:

SI=510H BX=230H

七、程序设计:

1.参考答案如下:

DATA SEGMENT

DAT DW 0A5D2H

DAT1 DB ?

DAT2 DB ?

DAT3 DB ?

DAT4 DB ?

DATA ENDS

CODE SEGMENT

ASSUME CS:CODE, DS: DATA

START:

MOV AX, DATA

MOV DS, AX

MOV AX, DAT

MOV BX, 0F0FH

AND BX, AX

MOV DAT1, BL

MOV DAT3, BH

MOV BX, 0F0F0H

AND BX, AX

MOV DAT2, BL

MOV DAT4, BH

MOV AH, 4CH

INT 21H

CODE ENDS

END START

2.参考答案如下:

分析:假设子程序的入口参数成绩表长度放在CX中,SI指向成绩表首单元;出口参数放在S6, S7,S8,S9和S10单元中,并且各单元初值均为0。参考子程序如下:

;子程序名:GRADES

;功能:统计成绩表GRADES中各个分数段的人数

;入口参数:CX中为成绩表长度,SI指向成绩表首单元

;出口参数:各个分数段人数分别放在存储单元S6, S7,S8,S9和S10中

;所用寄存器:AL, CX,SI

GRADES PROC

PUSH CX ;保护用到的寄存器

PUSH SI

PUSH AX

NEXT: CMP CX,O ;判断成绩表是否结束

JZ EXIT

DEC CX

MOV AL,[SI] ;将要比较的成绩放在AL中

INC SI

CMP AL,100

JB GRADE9 ;小于100,转向GRADE9

INC[S10];S10单元内容增1

JMP NEXT

GRADE9:CMP AL,90

JB GRADE8 ;小于90,转向GRADE8

INC [S9] ;S9单元内容增1

JMP NEXT

GRADE8:CMP AL,80

JB GRADE7 ;小于80,转向GRADE7

INC[S8];S8单元内容增1

GRADE7:CMP AL,70

JB GRADE6 ;小于70,转向GRADE6 INC [S7] ;S7单元内容增1

JMP NEXT

GRADE6: INC [S6];S6单元内容增1 JMP NEXT

EXIT: POP AX

POP SI

POP CX

RET

GRADES ENDP

3.

(1)参考程序如下:

DATA SEGMENT

BUF1 DB -10,0,11,55,125,38,-69,… ;N字节数据

CN EQU $-BUF1

BUF2 DB CN DUP(?)

DATA ENDS

CODE SEGMENT

ASSUME CS:CODE,DS:DATA

START: MOV AX,DATA

MOV DS,AX

MOV BX,OFFSET BUF1

LEA SI,BUF2

MOV CX,CN

LOP1: MOV AL,[BX]

MOV [SI],AL

INC BX

INC SI

LOOP LOPl

MOV AH,4CH

INT 21H

CODE ENDS

(2)程序的数据定义部分与(1)中相同,不再重复。参考程序段如下:CODE SEGMENT

ASSUME CS:CODE,DS:DATA,ES:DATA

START: MOV AX,DATA

MOV DS,AX

MOV ES,AX

MOV SI,OFFSET BUF1

MOV DI,OFFSET BUF2

CLD

MOV CX,CN

REP MOVSB

MOV AH,4CH

INT 21 H

CODE ENDS

END START

(3)程序的开头和结尾与(2)中相同,不再重复。参考程序段如下:MOV DS,AX

MOV ES,AX

MOV SI,OFFSET BUF1

MOV DI,OFFSET BUF2

CLD

MOV CX,CN

LOP: LODSB

INC SISTOSB

INC DI

LOOP LOP

4.参考答案如下:

DATA SEGMENT

BUFFER DB OOH, 12H,3BH,43H,60H,OCH

DB 8AH,OABH,37H,OFFH,32H,47H

COUNT EQU $-OFFSET BUFFER

DATA ENDS

CODE SEGMENT

ASSUME CS:CODE,DS:DATA

START: MOV AX,DATA

MOV DS,AX

MOV SI,OFFSET BUFFER

MOV CX,COUNT

MOV AL,[SI] ;把第一个数取到AL中

INC SI

DEC CX ;比较COUNT-1次

COMPA: CMP AL,[SI];比较,找出大数

JA NEXT

MOV AL,[SI]

NEXT: INC SI

LOOP COMPA ;比较完否?

MOV BL,AL ;是,大数在AL中,将其存入BX中MOV DL,AL

MOV CL,4

SHR DL,CL

CMP DL,OAHJB L1

ADD DL,7

Ll: ADD DL,30H

MOV AH,02H

INT 21H ;显示高位

MOV DL,BL ;将大数放到DL中

AND DL,OFH ;将高4位屏蔽

CMP DL,OAH

JB L2

ADD DL,7

L2: ADD DL,30H

MOV AH,02H

INT 21 H ;显示低位

MOV AH,4CH

INT 21H

CODE ENDS

END START

5.参考答案如下:

DATA SEGMENT

ADRX DW 144

ADRY DW 12

DATA ENDS

CODE SEGMENT

ASSUME CS:CODE,DS:DATA START: MOV AX,DATA MOV DS,AX

MOV AX,ADRX

MOV DX,O

DIV ADRY

CMP DX,O

JZ NEXT

MOV DL,'1’

JMP EXIT

NEXT: MOV DL,'0' EXIT: MOV AH,02H

INT 21H

MOV AH,4CH

INT 21H

CODE ENDS

END START

华电微机原理与技术汇编语言题目及答案

一微机原理与接口技术汇编题目 (1)数据块传送 1、将数据段中2000H单元开始存放的10个数(8位数)传送到3000H开始的10个字节中。 2、将数据段DATA1中的10个字数据(16位数)传送到数据段DATA2中。 提示: 1、指定数据的起始地址:(如果不指定起始地址,则起始地址为0000H) DATA SEGMENT ORG 2000H DB 1,,2,3,4,5,6,7,8,9,10 ; DB定义字节数据 ORG 3000H DB 10 DUP(0); 预留10个单元存放结果,初值预定义为0 DATA ENDS 定义的存单元为:

2、定义字数据命令为:DW DATA1 SEGMENT DW 1,,2,3,4,5,6,7,8,9,10 ; DW定义字数据DATA1 ENDS 一个字为两个字节,在存中低位在前,高位在后。

(2)查表 1、已知0~15的平方值表,查表求X(X是0到15 间任一数)的平方值,送到Y单元,用两种方法。 2、已知0~255的平方值表,查表求X的平方值,送到Y单元。 提示: 0到15的平方表,每个平方值为一个字节; 0到255的平方表,每个平方值为2个字节;调试程序,平方表中的数据定义几个就行,目的是程序正确即可。 一个字为两个字节,在存中低位在前,高位在后。

(3)计算 1、计算多字节数据67788H与99AABBCCDDEEFF00H的和。 2、计算8字节的BCD码十进制数67788H与43322H的和 3、计算10个字数据的和(数据自己定义)。 提示; 1、多字节数据在存中存放,低位在前,高位在后 DAT1 DB 88H,77H,66H,55H,44H,33H,22H,11H DAT2 DB 00H,0FFH,0EEH,0DDH,0CCH,0BBH,0AAH,99H DAT3 DB 9 DUP(0) 2、BCD十进制加法 二进制加法指令: ADD BCD十进制加法: ADD

微机原理与汇编语言复习题及参考答案

、选择题 : 1. 2. 3. 中南大学现代远程教育课程考试复习题及参考 答案 微型机原理与汇编语言 设AL=0A8H CX=2 CF=1,执行RCL AL , CL 指令后,AL 中的值为 A. 51H B. A3H C. 47H D. 0C5H 下述指令的执行结果是 MOV AL , 0C2H AND AL , 0F0H A.AL=40H B.AL=20H 完成对CL 寄存器的内容乘以 A.ROL CL , 1 B.MUL 4 ROL CL , 1 C.AL=0C0H D.AL=0E0H 4 的正确操作是 C.SHL CL SHL CL ,2 ,CL ,1 D.MOV CL ,1 SHL CL BH 中的数一定为奇数,应执行的指 C. XOR BH ,01H D. TEST 无论BH 中原有的数是奇数或偶数,若要使 A. ADD BH , 01H B. OR BH , 01H 假设(AL )= 37H ,( BL )= 95H ,执行指令 IMUL BL 后(AX )= A. 0E903H B. 2003H 下面的数据传送指令中,错误的操作是 A. MOV SS:[BX+DI] , 1000H C. MOV WORD PTR[BX], 1000H 7. CPU 要访问的某一存储单元的实际地址称 4. 5. 6. C. 0DBBH D. 2008H B. MOV DX D. MOV DS ,1000H ,2000H A .段地址 B.偏移地址 C.物理地址 8. 某存储单元的物理地址是 12345H,可以作为它的段地址有 A . 2345H B . 12345H C . 9. 计算机能直接识别的的语言 A .汇编语言 B .机器语言 10. 下列指令中操作数在代码段中的是 A . MOV AL,25H B . ADD AH,BL C . D.逻辑地址 12340H D . 1234H C.咼级语言 D.低级语言 INC DS:[25] D . CMP AL,BL 11. 直接、间接、立即三种寻址方式指令的执行速度,由决至慢的排序为 A .直接、立即、间接 C.立即、直接、间接 12. 若栈顶的物理地址是 A . 2010211 B B .直接、间接、立即 D .不一定 2010011, 当执行完指 令 CALL AX 后, . 2010111 13. 当执行完下列指令序列后,标志位 MOV AX,OC126H MOV BX,5AB7H SUB AX,BX A . 0, 0 B . 0, 1 14. JMP BX 的目标地址偏移量是() A . SI 的内容 B . SI C . 200FFH CF 和 OF 的值是 . 1, 0 D O 所指向的内存字单元之内容 C . IP+SI 的内容 D . IP+[SI] 15. 指令MOV AX,10[BX]的源操作数的寻址方式是 A .基址寻址 B .寄存器寻址 C.变址寻址 D .寄存器相对寻址 16. 指出下列哪个数据在汇编语言中是非法的。 A . 19BH+25D B . 25+AL C . 108-102Q D . 101B*OABH 17. 用来存放即将执行的指令的偏移地址的寄存器是 A . SP B . IP C . BP BH , ( 01H 栈顶的物理地址是( D . 200FEH ( . CS

微机原理与汇编语言复习题及参考答案

微机原理与汇编语言复习题及参考答案 ——CSDN下载频道提供,请尊重原创 一、选择题: 1. 设AL=0A8H,CX=2,CF=1,执行RCL AL,CL指令后,AL中的值为() A. 51H B. A3H C. 47H D. 0C5H 2. 下述指令的执行结果是() MOV AL,0C2H AND AL,0F0H A.AL=40H B.AL=20H C.AL=0C0H D.AL=0E0H 3. 完成对CL寄存器的容乘以4的正确操作是() A.ROL CL,1 B.MUL 4 C.SHL CL,1 D.MOV CL,2 ROL CL,1 SHL CL,1 SHL CL,CL 4. 无论BH中原有的数是奇数或偶数,若要使BH中的数一定为奇数,应执行的指() A. ADD BH,01H B. OR BH,01H C. XOR BH,01H D. TEST BH,01H 5. 假设(AL)= 37H,(BL)= 95H,执行指令IMUL BL后(AX)= () A. 0E903H B. 2003H C. 0DBBH D. 2008H 6. 下面的数据传送指令中,错误的操作是() A. MOV SS:[BX+DI],1000H B. MOV DX,1000H C. MOV WORD PTR[BX],1000H D. MOV DS,2000H 7. CPU要访问的某一存储单元的实际地址称() A.段地址B.偏移地址C.物理地址D.逻辑地址 8. 某存储单元的物理地址是12345H,可以作为它的段地址有() A.2345H B.12345H C.12340H D.1234H 9. 计算机能直接识别的的语言() A.汇编语言 B.机器语言C.高级语言D.低级语言 10. 下列指令中操作数在代码段中的是() A.MOV AL,25H B.ADD AH,BL C.INC DS:[25] D.CMP AL,BL 11.直接、间接、立即三种寻址方式指令的执行速度,由决至慢的排序为()A.直接、立即、间接B.直接、间接、立即 C.立即、直接、间接D.不一定 12.若栈顶的物理地址是2010011,当执行完指令CALL AX后,栈顶的物理地址是()A.2010211 B.2010111 C.200FFH D.200FEH 13.当执行完下列指令序列后,标志位CF和OF的值是() MOV AX,OC126H MOV BX,5AB7H SUB AX,BX A.0,0 B.0,1 C.1,0 D.1,1 14. JMP BX的目标地址偏移量是(D)。 A.SI的容B.SI所指向的存字单元之容 C.IP+SI的容D.IP+[SI] 15.指令MOV AX,10[BX]的源操作数的寻址方式是() A.基址寻址B.寄存器寻址MOV AX,BX C.变址寻址AX【BX+DI】(只能用BX,BP;SI和DI) D.寄存器相对寻址 16.指出下列哪个数据在汇编语言中是非法的。()

微机原理与汇编语言教学大纲

《微机原理与汇编语言》课程教学大纲一、课程基本信息 二、教学目标和要求 本课程是计算机专业的专业主干课。课程以当今主流微处理器80X86为结合点,分析它的结构特点、操作原理、指令系统以及汇编语言设计的基本方法,为后续课程打下必要的基础。通过本课程的学习,要求学生掌握微型计算机的基本

工作原理、汇编语言程序设计基本方法、微型计算机接口技术、建立微型计算机系统的整体概念,形成微机系统软硬件开发的初步能力。应能掌握计算机的基本工作原理及汇编语言编程的技能和技巧,养成良好的程序设计风格,为今后的工作打下必要的技术基础。 三、教学难点 重点是8086CPU内部结构,引腿信号及功能,指令系统;汇编语言程序设计;接口的基本技术,接口芯片的内部结构和工作原理。难点是CPU操作时序,各种接口芯片的控制字,模式字的设置及其含义,接口与外设子系统的硬件设计及软件编程。 四、教学内容及基本要求 第一章微型机算计概述 (2学时) 教学目标和要求:理解微型机的分类和发展概况;掌握微处理器、微型计算机和微型机系统的差别;掌握CPU的功能和组成部件;掌握计算机的基本结构。 教学重点和难点:无。 教学方式:(课堂讲授) 第一节微型计算机的特点和发展 一、微型计算机的特点 二、微型计算机的发展 第二节微型机的分类 一、微型计算机的分类 第三节微处理器、微型计算机和微型计算机系统 一、微处理器 二、微型计算机 三、微型计算机系统 第四节微型机算机的应用 一、微型计算机的应用 复习思考题: 1. 微处理器、微型计算机和微型计算机系统之间有什么不同?

2. 微型计算机采用总线结构有什么优点? 3. 数据总线和地址总线在结构上有什么不同之处? 第二章 16位和32位微处理器 ( 6学时 ) 教学目标和要求: 1、掌握:8086微处理器的编程结构,常用引腿信号的功能,8086的中断系统,总线操作及时序; 2、理解:80386的体系结构,三种工作方式,指令流水线和地址流水线,虚拟存储机制和片内两级存储管理;Pentium采用的先进技术,原理结构,技术发展。 教学重点和难点:8086微处理器的结构,内部寄存器的功能,主要的引脚信号及功能,中断响应过程,存储器组织和I/O组织。 教学方式:(课堂讲授6学时) 第一节 16位微处理器8086 (2学时 ) 一、8086的编程结构 总线接口部件和执行部件的组成及各自功能,8086总线周期的概念。 二、8086的引腿信号和工作模式 1. 最小模式和最大模式的概念 为了适应各种应用场合,在设计8086/8088CPU芯片时,使它们可以在两种模式下工作,及最小模式和最大模式。 2. 8086/8088的引腿信号和功能 8086/8088CPU有40条引腿,这里介绍在两种模式下公用的32条引腿和他们的传递方向及有效跳变。 3. 最小模式 讲述8086在最小模式下的典型配置及有关引腿信号。 4. 最大模式 讲述8086在最大模式下的典型配置及有关引腿信号。 三、8086的操作和时序 1. 系统复位和启动操作 8086/8088复位时各内部寄存器的值,复位时序,总线信号状态。

汇编语言与微机原理实验指导书范本

汇编语言与微机原理实验指导书

《汇编语言与微机原理》实验指导书 编写者:董建怀 编写时间: -9-10

实验一.熟悉DOS环境和DEBUG调试软件的使用 一、实验要求: 必做 二、实验类型: 验证 三、实验学时:2 四、实验地点:机房 五、实验目的: 1、.熟悉DOS环境和DEBUG调试软件的使用方法。 2、掌握DEBUG常见命令A、U、D、E、R、T、G的使用,用DEBUG调试简单程序段。 六、实验内容: (一)、熟悉DOS环境 1、MS-DOS的启动:开始—程序—附件—MS-DOS方式(命令提 示符)。 2、MS-DOS全屏方式和窗口方式的切换:“ALT”+ “ENTER”。 3、MS-DOS工具栏的打开:“ALT”+空格键。 4、MS-DOS方式下的选定、复制和粘贴:利用菜单栏下”编辑” 菜单项中的“标记”、“复制”和“粘贴”的功能来实 现。 5、MS-DOS方式的退出:EXIT。 练习:进入MS-DOS方式,并将屏幕上显示的全部内容复制

到一WORD文档中。 (二)、熟悉一些常见的DOS命令 1、更改盘符,如:C:\WINDOWS>d:并按“ENTER”,显示:D:\>(盘符更改为D:)。 2、建立子目录(文件夹)MD,如C:\>MD FOX (在当前驱动器C盘下创立子目录FOX)。 3、显示当前目录CD,如:C:\>CD WINDOWS,显示:C:\WINDOWS>(即从当前目录C:\进入到C:\WINDOWS目录)。 4、显示磁盘目录的内容DIR,如:C:\WINDOWS>,显示的内容即为当前目录C:\WINDOWS中的所有内容。 5、返回上级目录,如:C:\WINDOWS>cd ..,显示C:\>(即从当前目录C:\WINDOWS返回到它的上级目录C:\)。 练习:在MS-DOS方式下,进入C:\WINDOWS\SYSTEM目录,并显示该目录下的所有内容,然后返回C盘的根目录(C:\)。 (三)、熟悉调试程序DEBUG.EXE的应用,练习DEBUG的常见命令 实践1:利用DEBUG.EXE的A、D、U命令,观察指令MOV AH,[BX+DI+50H],对应的机器码是什么?,该指令是几个字节的指令?并对机器码进行反汇编,观察对应的指令是什么?ADD [2345H][BX][DI],DX的机器码是什么? 该指令是几个字节的指令? 并对机器码进行反汇编,观察对应的指令是什么? 实践2:在DEBUG.EXE方式下(利用A、G命令), 分析两个数

位微机原理汇编语言及接口技术教程课后习题答案

《16/32位微机原理、汇编语言及接口技术教程》 部分习题参考解答 第1章微型计算机系统概述 〔习题〕 什么是通用微处理器、单片机(微控制器)、DSP芯片、嵌入式系统? 〔解答〕 通用微处理器:适合较广的应用领域的微处理器,例如装在PC机、笔记本电脑、工作站、服务器上的微处理器。 单片机:是指通常用于控制领域的微处理器芯片,其内部除CPU外还集成了计算机的其他一些主要部件,只需配上少量的外部电路和设备,就可以构成具体的应用系统。 DSP芯片:称数字信号处理器,也是一种微控制器,其更适合处理高速的数字信号,内部集成有高速乘法器,能够进行快速乘法和加法运算。 嵌入式系统:利用微控制器、数字信号处理器或通用微处理器,结合具体应用构成的控制系统,其典型的特点是把计算机直接嵌入到应用系统之中。 〔习题〕 说明微型计算机系统的硬件组成及各部分作用。 〔解答〕 CPU:CPU也称处理器,是微机的核心。它采用大规模集成电路芯片,芯片内集成了控制器、运算器和若干高速存储单元(即寄存器)。处理器及其支持电路构成了微机系统的控制中心,对系统的各个部件进行统一的协调和控制。 存储器:存储器是存放程序和数据的部件。 外部设备:外部设备是指可与微机进行交互的输入(Input)设备和输出(Output)设备,也称I/O设备。I/O设备通过I/O接口与主机连接。 总线:互连各个部件的共用通道,主要含数据总线、地址总线和控制总线信号。

〔习题〕 什么是总线?微机总线通常有哪3组信号?各组信号的作用是什么? 〔解答〕 总线:传递信息的共用通道,物理上是一组公用导线。 3组信号线:数据总线、地址总线和控制总线。 (1)地址总线:传输将要访问的主存单元或I/O端口的地址信息。 (2)数据总线:传输读写操作的数据信息。 (3)控制总线:协调系统中各部件的操作。 〔习题〕 简答如下概念: (1)计算机字长 (2)取指-译码-执行周期 (3)ROM-BIOS (4)中断 (5)ISA总线 〔解答〕 (1)处理器每个单位时间可以处理的二进制数据位数称计算机字长。 (2)指令的处理过程,即指处理器从主存储器读取指令(简称取指),翻译指令代码的功能(简称译码),然后执行指令所规定的操作(简称执行)的过程。 (3)ROM-BIOS是“基本输入输出系统”,操作系统通过对BIOS的调用驱动各硬件设备,用户也可以在应用程序中调用BIOS中的许多功能。 (4)中断是CPU正常执行程序的流程被某种原因打断、并暂时停止,转向执行事先安排好的一段处理程序,待该处理程序结束后仍返回被中断的指令继续执行的过程。 (5)ISA总线是指IBM PC/AT机上使用的系统总线。 〔习题〕 下列十六进制数表示无符号整数,请转换为十进制形式的真值: (1)FFH (2)0H (3)5EH (4)EFH 〔解答〕 (1)255 (2)0 (3)94 (4)239

微机原理与汇编语言 习题

微机原理与汇编语言习题 1.ZF标志位是标志结果是否为零的,若结果为零,ZF为________,否则ZF为_______。当ZF 为1时,SF为________。 2.调用程序与子程序之间的参数传递方法有四种,即堆栈法、_______、______、______。 3.宏指令定义必须由伪指令________开始,伪指令______结束,两者之间的语句称为________。 4.三个重复前缀指令为__________、__________、________。 5.8086/8088 CPU可访问2个独立的地址空间,一个为存贮器地址空间,其大小为____个字节; 另一个为______,其大小为_______字节。 6.当_______________时,CPU便进入等待状态(Tw)。 7.最小模式系统除CPU、存储器、I/O接口和总线外,至少还应配置________、__________、 _________三种芯片部件或电路。 8.8086内部由_________和_______两部分组成,其作用分别是_______和______。 9.在汇编语言中,一个标号和过程有和两种属性。前者表明在段内转移和调用,后 者表示在段间转移和调用。 10.8086/8088的存储器是分段的,因此存储单元的物理地址是由和组合而成。 11.汇编语言源程序的扩展名是,目标程序的扩展名是,通常产生的可执行程序 的扩展名是。 12.指令操作数可以存放在指令中,也可以存放在CPU的寄存器中,大多数存放在存储器中,它们 分别被称为立即、寄存器和直接寻址方式。 13.微型计算机一般都采用总线结构,系统总线的信号线有三组,即数据总线、地址总线和 控制总线。 14.若要判断无符号数运算是否溢出,应根据CF 标志位;而判断有符号数运算是否溢出,应 根据OF 标志位。 15.8086/8088端口地址的范围是0000H ~ FFFFH。 16.汇编语言源程序中的语句有三种类型,他们是指令语句,伪指令语句和语句。 17.指令SAR可用来有符号数数除以2,而指令SHR则可用来无符号数数除以2。 18.用二进制代码组成的计算机能直接识别的语言称为机器语言。用机器指令的助记符以 及伪指令,宏指令表示的一种面向机器的语言称汇编语言,用该语言编写的程序需经过汇编程序翻译,成为计算机能直接识别并执行的程序称目标程序。 19.数据段中有以下定义: ARRAY1 EQU 16H ARRAY2 DW 16H 请指出下面两条指令源操作数的寻址方式: MOV AX, ARRAY1 ;寻址方式:立即寻址方式。 MOV AX, ARRAY2 ;寻址方式:直接寻址方式。 20.在数据段中使用字符串时,该字符串必须用括起来。当定义含有多个字符的字符串时,

汇编语言与微机原理综合性实验报告

综合性实验报告 2012-2013-1 课程名称:《汇编语言与微机原理》班级:10级计算机(1)班 学号:1006111079 姓名:王东亮

实验项目:基于DOS系统功能调用、串处理指令的用户管理实验 1 实验目的与要求: 通过本综合性实验,可以达到以下目的: 1、掌握内存中数据的存储与管理方法; 2、掌握使用DOS系统功能调用的方法进行程序设计的三个基本步骤; 3、掌握使用DOS系统功能调用进行字符串显示与录入、存储的程序设计; 4、掌握字符串处理指令的功能、格式及使用方法; 5、掌握使用汇编语言进行程序设计、调试的方法。 2 实验内容: 1、进行子程序设计,功能为: (1)调用DOS系统功能进行字符串录入提示;并对用户根据提示输入的用户名进行存储;(2)系统自动匹配录入用户名与预设用户名,若相同,则提示“ENTER THE SYSTEM….”,否则,提示“REFUSED TO ENTER!”。 2、调用DOS系统21H中断的25H号功能,将此子程序的入口地址写入中断矢量表,中断矢 量号定义为60H。 3、定义主程序,功能如下: (1)在数据存储区域预设用户名; (2)使用INT 60H中断指令进行中断调用; 4、调试、执行程序并记录调试结果。 3 实验过程(要求在实验报告中写出全部代码,并提交纸质实验报告和电子文档,电子文档为实验报告、源代码、obj、exe文件的压缩包) 参考过程如下: 1、进入DOS操作系统; 2、键入EDIT 进入全屏幕编辑环境; 3、建立源文件.ASM 并保存; 4、返回DOS系统; 5、用汇编程序MASM对源文件汇编产生目标文件.OBJ; 6、用链接程序LINK产生执行文件.EXE; 7、执行程序; 8、进入DEBUG,进行程序功能调试的方法。 完整源代码如下: DATA SEGMENT WAITFINPUT DB 100 DB ? DB 100 DUP(?) USER_NAME DB "BRUTH" MESG DB "PLEASE INPUT THE USERS' NAME(=5):$" WEL DB "ENTER THE SYSTEM...$"

汇编语言、微机原理及接口技术期末复习试卷以及参考答案八教学文案

重庆邮电大学2006/2007学年第二学期期末考试题 微机原理与接口技术考试题(A 卷) 一、单项选择题(每题1分,共20题) 1、一般,微机系统硬件由___部分组成,包括______。 A.4,CPU、存储器、I/O设备和接口电路 B.3,存储器,控制器和显示器 C.2,运算器和显示器 D.4,存储器,运算器,显示器和键盘 2、80X86微机系统有三条总线,它们是___________。 A. 地址总线、数据总线和控制总线 B. 地址总线、信息总线和存储器总线 C. 输入总线和输出总线 D. 单总线、面向微处理器双总线和面向存储器双总线 3、80X86微机中用来指出下一条要被执行指令的偏移地址的部件是___。A.CS B.DS C.ES D.IP

4、在汇编语句MOV BL,’A’中,源操作数的寻址方式是___________。A.直接寻址B.立即寻址 C.基址寻址D.寄存器间接寻址 5、以下指令中正确的是___________。 A.MOV DS,2D00H B.MOV CL,270 C.IN AL,DX D.MOV [DI],[SI] 6、已定义数据段 DATA SEGEMENT ORG 0213H DA1 DB 15H,34H,55H ADR DW DA1 DATA ENDS 能使AX中数据为偶数的语句是() A.MOV AX,WORD PTR DA1 B.MOV AL,DA1+2

C.MOV AL,BYTE PTR ADR+1 D.MOV AX,WORD PTR DA1+2 7、已知DS=1000H,ES=2000H,SI=0300H,内存10310H开始的两个单元中存放3A4BH,内存20310H开始的两个单元中存放4C5DH,则语句LEA B X,[SI+10H] 执行后,BX的值为________。 A.3A4BH B.4C5DH C.0310H D.3D5BH 8、MOV SP,4210H PUSH AX 执行上述指令后,SP寄存器的值是() A.4211H B.420EH C.420FH D.4212H 9、下列指令中不影响进位标志CF的指令是___________。 A.SUB AX,BX B.ROL AL,1 C.INC CX D.ADD AL,BL 10、设AH=0,AL=06H,BL=09H,执行指令 ADD AL,BL

微机原理与汇编语言_实验3_循环程序设计实验汇总

微机原理与汇编语言 实验报告 姓名x x x学号xxxxxx 专业班级计科x班 课程名称微机原理与汇编语言实验日期2014.10.22 实验名称循环程序设计实验成绩 一、实验目的 1、掌握循环程序的设计方法。 2、掌握比较指令、转移指令和循环指令的使用方法。 3、进一步掌握调试工具的使用方法。 二、实验内容 1、实验原理 (1)键盘输入的十进制数如368在计算机中是以33H,36H,38H形式存放的,如何将它们转换为一个二进制数101110000B,以便对累加循环的循环次数进行控制是本程序首先要解决的问题 (2)累加结果为一个16位的二进制数,为了显示结果,必需把它们转换为十进制数 2、实验步骤 (1)流程图 (2)实验源码 .model small .stack ;定义堆栈段 .data ;定义数据段 inf1 db "Please input a number(1-627):$" inf2 db 0ah, 0dh, "1+2+......+$" ibuf db 7, 0, 6 dup(0) obuf db 6 dup(0) .code start: mov ax, @data mov ds, ax mov dx, offset inf1 ;将屏幕输入的十进制数(存放于ibuf)转化为二进制数存储于ax 中 mov ah, 09h int 21h mov dx, offset ibuf mov ah, 0Ah int 21h mov cl, ibuf+1 mov ch, 0 mov si, offset ibuf+2 mov ax, 0 loop1: mov dx, 10 mul dx and byte ptr [si], 0Fh add al, [si] 从键盘输入一个十进制数,并将其转换为二进制数,存放在AX中 开始 结束 素、、 (CX)-1=0 累加循环次数送CX(MOV CX,AX)AX清0(AX中存放累加和) BX送1(BX存放每次循环累加的数,每循环一次,BX值加1) ADD AX,BX INC BX 累加和(在AX中)转换为十进制数并 显示 Y N

微机原理与汇编语言复习题及参考答案

中南大学网络教育课程考试复习题及参考答案 微型机原理与汇编语言 一、单项选择题: 1.设AL=0A8H,CX=2,CF=1,执行RCL AL,CL指令后,AL中的值为() A.51H B.A3H C.47H D.0C5H 2.下述指令的执行结果是() MOV AL,0C2H AND AL,0F0H A.AL=40H B.AL=20H C.AL=0C0H D.AL=0E0H 3.完成对CL寄存器的内容乘以4的正确操作是() A.ROL CL,1 B.MUL4 C.SHL CL,1 D.MOV CL,2 ROL CL,1SHL CL,1SHL CL,CL 4.无论BH中原有的数是奇数或偶数,若要使BH中的数一定为奇数,应执行的指() A.ADD BH,01H B.OR BH,01H C.XOR BH,01H D.TEST BH,01H 5.假设(AL)=37H,(BL)=95H,执行指令IMUL BL后(AX)=() A.0E903H B.2003H C.0DBBH D.2008H 6.下面的数据传送指令中,错误的操作是() A.MOV SS:[BX+DI],1000H B.MOV DX,1000H C.MOV WORD PTR[BX],1000H D.MOV DS,2000H 7.CPU要访问的某一存储单元的实际地址称() A.段地址 B.偏移地址 C.物理地址 D.逻辑地址 8.某存储单元的物理地址是12345H,可以作为它的段地址有() A.2345H B.12345H C.12340H D.1234H 9.计算机能直接识别的的语言() A.汇编语言 B.机器语言 C.高级语言 D.低级语言 10.下列指令中操作数在代码段中的是() A.MOV AL,25H B.ADD AH,BL C.INC DS:[25] D.CMP AL,BL 11.直接、间接、立即三种寻址方式指令的执行速度,由决至慢的排序为() A.直接、立即、间接 B.直接、间接、立即 C.立即、直接、间接 D.不一定 12.若栈顶的物理地址是2010011,当执行完指令CALL AX后,栈顶的物理地址是() A.2010211 B.2010111 C.200FFH D.200FEH 13.当执行完下列指令序列后,标志位CF和OF的值是() MOV AX,OC126H MOV BX,5AB7H SUB AX,BX A.0,0 B.0,1 C.1,0 D.1,1 14.JMP BX的目标地址偏移量是() A.SI的内容 B.SI所指向的内存字单元之内容 C.IP+SI的内容 D.IP+[SI] 15.指令MOV AX,10[BX]的源操作数的寻址方式是() A.基址寻址 B.寄存器寻址 C.变址寻址 D.寄存器相对寻址 16.指出下列哪个数据在汇编语言中是非法的?() A.19BH+25D B.25+AL C.108-102Q D.101B*OABH 17.用来存放即将执行的指令的偏移地址的寄存器是() A.SP B.IP C.BP D.CS 18.源变址寄存器是() A.SI B.DI C.SP D.BX

微机原理与汇编语言-模拟题

《微机原理与汇编语言》模拟题 一.单选题 1.属于8086的专用(控制)寄存器有(). A.AXBXCXDX B.SPIPFLAGS C.SIDI D.以上三者都是 [答案]:B 2.有关com文件描述不正确的是(). A.可执行文件 B.没有文件信息的标题区 C.占用存储空间大 D.程序不分段入口点必须是100H [答案]:C 3.数据段中定义stringDW10dup(10dup(1),3,4),则lengthstring的值为(). A.10 B.100 C.120 D.20 [答案]:A 4.对MOV指令,不正确的是(). A.MOVAX,100H B.MOVAX,CS C.MOVBP,IP D.MOVVAR,100H [答案]:D 5.对MOV指令,正确的是(). A.MOVBL,AX B.MOVAX,CS C.MOVDS,100H D.MOVES,DS [答案]:B 6.R进制数转换成十进制的方法是(). A.权和系数乘后累加 B.降幂法 C.降幂法和除法 D.除法 [答案]:A

7.在编程时,常常将多次使用的功能用一条()来代替. A.指令 B.伪指令 C.宏指令 D.以上都不是 [答案]:C 8.属于8086的变址寄存器有(). A.AXBXCXDX B.SPBPIP C.SIDI D.以上三者都是 [答案]:C 9.不定重复汇编伪操作的指令是(). A.IRP B.IRPN C.REPT D.macro [答案]:A 10.假设程序中的数据定义PNAMEDW16DUP(?)后接着定义PLENTHEQU$-PNAME,它表示什么意义是(). A.占16字节 B.占32个字节 C.变量PNAME的长度 D.变量PNAME的地址 [答案]:B 11.操作符TYPE后可以是变量/标号/常数,回送变量或标号的类型值.其中常数回送的类型值为(). A.1 B.2 C.-1 D.0 [答案]:D 12.外部接口组成由一组”寄存器”及相关”控制电路组成”,其中存放外设和CPU传送过来的数据的寄存器是(). A.数据寄存器 B.状态寄存器 C.命令寄存器 D.以上都是

“微机原理与汇编语言”期末试题.

“微机原理与汇编语言”期末试题 一、填空(每空小1分,共30分) 1.电子计算机的主要应用领域有()、()、()。 2.电子计算机的发展历程是()、晶体管时代、()、( )。 3.十进制数11.375转换为二进制数为();二进制数1101101 转换为十进制数为()。 4.十进制数7928转换为十六进制数为(), 十六进制数3A57 转换为十进制数为()。 5.十六进制数DA2B转换为二进制数为(), 二进制数 110111100101.1011转换为十六进制数为()。 6.A=+0110101,[A]反=( ),[A]补=( );B=-0110101,[B] 反=( ) ,[B] 补=( )。 7.37的BCD编码是()。 8.从功能上看,微机由中央处理器、()、外部设备、( )和()五个部分组成。 9.CPU由( )和()两部分组成。 10.程序设计的基本的结构有顺序结构、()、()。 11.中断处理的过程是保存断点、()、()、()、( )。 12.打印机是()设备,扫描仪是()设备。 二、名词解释(每小题4分,共20分) 1.随机读写存储器 2.寄存器间接寻址方式 3.控制总线 4.局部总线 5.并行传输

三、改错题(下列各小题均有错,请针对题意改正其错误,或补充其不足。 每小题2分,共18分) 1.在浮点数加减运算中,阶码与尾数作为一个整体相加减。 2.在微程序控制方式中,每一条机器指令用一条微指令解释执行。 3.若总线地址为26位,则最大访存空间为6M。 4.DMA方式是指:由DMA控制器运行I/O程序,以实现外围设备与主存之间的数据直传。 5.SUB 0FFH ,BX; 6.MOV DX,AL; 7.ADD BUF1,BUF2; 8.MOV AX, 20H[SI][DI]; 9.MOV CS,AL; 10.MOV E43H,E43H 四、程序分析与设计(每小题2分,共10分) 1.将寄存器DX的内容赋于AX寄存器。 2.将立即数8EFH传送给BX寄存器。 3.将数据段偏移地址为2FH的存储器中的提供给DX寄存器。 4.将AL寄存器内容传送给由DI寄存器指定的数据段偏移地址的存储单元。5.将字节量数据11H送入用BX和DI的基址变址寻址的主存单元。 五、问答题(共30分) 1.什么叫寻址方式?常用的寻址方式有哪些?(5分) 2.什么是变量,变量有哪些属性,如何使用这些属性?(9分) 3.比较说明中断方式与DMA方式的异同?(9分) 4.什么是有效地址?什么是物理地址?如何由有效地址求得物理地址?(7分)

微机原理及汇编语言作业 编程

第五大组题 5.一个32位数存放在以数据段的BUF单元开始的位置。编写子程序统计该数中含“1”的个数,并将其结果存入RSLT字节单元。 stac segment stack db 1024 dup(0) stac ends data segment RSLT db 00H ;使rslt初值为零 buf dd 12345678h ;定义buf data ends code segment 'code' assume cs:code,ds:data,ss:stac start: mov ax,data mov ds,ax mov cl ,32 call again ;调用子程序 mov ax ,4c00h int 21h gain proc ;定义过程 shr word ptr ds:[si+2],1 ;最高字逻辑右移一位,D16进入CF rcr word ptr ds:[si+0],1 ;CF移入D15,最低字右移一位进入CF nc L1 inc RSLT L1:again endp code ends end start 55.在0200H单元中有一个数x,利用移位和相加的办法,使x×10(假定x×10>255)后送回原单元。 stac segment stack db 1024 dup(0) stac ends data segment org 0200h ;将变量x的定位在0200h处 x db 56h data ends code segment 'code'

assume cs:code,ds:data,ss:stac start: mov ax,data mov ds,ax mov al,x ;把x放到al中 + xor ah,ah ;使AH=0,同时使CF=0 shl ax,1 ;AX=AL*2 mov bx,ax ;BX=AX=AL*2 shl ax,1 ;AX=AL*4 shl ax,1 ;AX=AL*4 add ax,bx mov x,al ;将ax中低八位放到x中 mov x+1,ah ;将ax中高八位放到x+1中 mov ax, 4c00h int 21h code e nds end start 75.编写子程序。将AL中的二进制数转换成对应的ASCII码(置于AL中)返回。主程序调用子程序实现上述功能。 .model small .stack .data .code start: mov ax,@data mov ds,ax mov al,28h call label1 ;调用子程序 mov ax,4c00h int 21h label1 proc and al,0fh ;只取al的低四位 or al,30h ;al高四位变成3(0~9的ASCII码是30h~39h) cmp al,39h ;是0~9还是0A~0Fh(A~F的ASCII的值是41h~46h) jbe htoend ;小于等于39h,al低4位的数值在0~9之间 add al,7 ;数值在0A~0F间,其ASCII码值还要加上7 htoend: ret ;子程序返回 label1 endp ;过程结束 end start

微机原理及汇编语言复习题

微机原理及汇编语言复习题 一、填空题 1.指令包括、两部分。 2.标号有3个属性,属性、属性和属性。 3.计算机远距离通信时,通过进行数字信号与模拟信号间的转换。 4.8086产生20位的地址,称为。 5.8086系统中,就有三种时间周期,分别是、、。 6.逻辑地址由两部分组成、。 7.堆栈段在存储区中的位置由、来规定。 8.8位无符号数表示的范围为。 9.16位无符号数表示的范围为。 10.微计算机中的带符号数通常用表示。 11.硬中断可分为非屏蔽中断和中断两种。 12.8位带符号数表示的范围为。 13.16位带符号数表示的范围为。 14.指令就是为调用程序调用过程(或称转子程序)而设立的。 15.8088微机系统有20条地址线,可寻址的最大物理内存容量为字节。 16.指令放在子程序的末尾,当子程序功能完成后,由它实现返回。 17.当微计算机系统在运行时,或者程序运行期间,遇到某些特殊情况,需要CPU停止执行 当前的程序,产生。 18.转去执行一组专门的例行程序进行处理,这种情况称为中断。这种例行程序称为。 19.已知逻辑地址为2F80H:38A0H,物理地址= 。 20.静态MOS存储器是靠存储信息,动态MOS存储器是靠存储信息。 21.存储器芯片地址译码方法有和两种方法。 22.用4K×4bit的存储器芯片构成32KB的存储器,所需要的芯片数是片。 23.与十进制数128等值的二进制数是。 24.受CLI和STI指令控制的中断是。 25.标号有3个属性,属性、属性和属性。 26.如果一个程序在执行前(CS)=0A8F0H,(IP)=2B40H,该程序的起始物理地址是。 27.三总线包括总线、总线和总线。 28.在8088系统中,一个段最大64KB,8088有条地址线,可以寻址的最大物理空 间为1MB。 29.十六进制数30AH转换为二进制原码是,转换为BCD码是。 30.在指令中立即数只能用作操作数,而不能用作目的操作数。 31.用2K×4位的存储芯片组成4K×8位的存储器,需要进行扩展。 32.在8088系统中,在构成存储器时使用全部20位地址线进行译码,即译码方式。 33.如果带符号数FFH加上带符号数01H,结果产生溢出。 34.CPU的寻址能力取决于的根数。 35.8086 CPU内部数据总线宽度为______位,外部数据总线宽度为______位。 36.8088 CPU内部数据总线宽度为______位,外部数据总线宽度为______位。 37.IO接口地址译码方法有和两种方法。 38.在8088系统中,中断类型码为7的中断向量的存放地址是。 39.当存储器的读出时间大于CPU所要求的时间,为保证CPU与存储器的周期配合,就需要

华电微机原理与技术汇编语言题目及答案

一微机原理与接口技术汇编题目 (1)数据块传送 1、将数据段中2000H单元开始存放的10个数(8位数)传送到3000H开始的10个字节中。 2、将数据段DATA1中的10个字数据(16位数)传送到数据段DA TA2中。 提示: 1、指定数据的起始地址:(如果不指定起始地址,则起始地址为0000H) DA TA SEGMENT ORG 2000H DB 1,,2,3,4,5,6,7,8,9,10 ; DB定义字节数据 ORG 3000H DB 10 DUP(0); 预留10个单元存放结果,初值预定义为0 DA TA ENDS 定义的内存单元为: 2、定义字数据命令为:DW DA TA1 SEGMENT DW 1,,2,3,4,5,6,7,8,9,10 ; DW定义字数据 DA TA1 ENDS 一个字为两个字节,在内存中低位在前,高位在后。

(2) 查表 1、已知0~15的平方值表,查表求X(X就是0到15 间任一数)的平方值,送到Y单元,用两种方法。 2、已知0~255的平方值表,查表求X的平方值,送到Y单元。 提示: 0到15的平方表,每个平方值为一个字节; 0到255的平方表,每个平方值为2个字节;调试程序,平方表中的数据定义几个就行,目的就是程序正确即可。 一个字为两个字节,在内存中低位在前,高位在后。

(3)计算 1、计算多字节数据1122334455667788H 与 99AABBCCDDEEFF00H 的与。 2、计算8字节的BCD 码十进制数1122334455667788H 与9988776655443322H 的与 3、计算10个字数据的与(数据自己定义)。 提示; 1、多字节数据在内存中存放,低位在前,高位在后 DA T1 DB 88H,77H,66H,55H,44H,33H,22H,11H DA T2 DB 00H,0FFH,0EEH,0DDH,0CCH,0BBH,0AAH,99H 2、 BCD 十进制加法 二进制加法指令: ADD BCD 十进制加法: ADD DAA;十进制调整指令,仅对AL 作为加法的累加与寄存器进行调整 (4)计算表达式的值 1 计算表达式)2/()7*)((+-=Y Y X Z 的值,已知X=10,Y=5。 提示:

《微机原理及汇编语言》习题

第一章思考题与习题 1.1计算机的发展到目前为止经历了几个时代?每个时代的特点是什么? 1.2计算机的特点表现在哪些方面?简述计算机的应用领域。 1.3冯·诺依曼型计算机的结构由哪些部分组成?各部分的功能是什么?分析其中数据信息 和控制信息的流向。 1.4计算机中的CPU由哪些部件组成?简述各部分的功能。 1.5微型计算机系统主要由哪些部分组成?各部分的主要功能和特点是什么? 1.6微型计算机的分类方法有哪些? 1.7 什么是微型计算机的系统总线?定性说明微处理器三大总线的作用。 1.8 微型计算机的总线标准有哪些?怎样合理地加以选择? 1.9 简述微型计算机的主要应用方向及其应用特点。 1.10 奔腾系列微处理器有哪些特点?与其它微处理器相比有哪些改进? 1.11 解释并区别下列名词术语的含义。 (1)微处理器、微计算机、微计算机系统 (2)字节、字、字长、主频、访存空间、基本指令执行时间、指令数 (3)硬件和软件 (4)RAM和ROM (5)机器语言、汇编语言、高级语言、操作系统、语言处理程序、应用软件 (6)CMOS、BIOS、Cache芯片 1.12 微型计算机系统软件的主要特点是什么?它包括哪些内容? 1.12 定性比较微型计算机的内存储器和外存储器的特点及组成情况。 第二章思考题与习题 2.1 简述计算机中“数”和“码”的区别,计算机中常用的数制和码制有哪些? 2.2 将下列十进制数分别转化为二进制数、八进制数、十六进制数和压缩BCD数。 (1)125.74 (2)513.85 (3)742.24 (4)69.357 (5)158.625 (6)781.697 2.3 将下列二进制数分别转化为十进制数、八进制数和十六进制数。 (1)101011.101 (2)110110.1101 (3)1001.11001 (4)100111.0101 2.4 将下列十六进制数分别转化为二进制数、八进制数、十进制数和压缩BCD数。 (1)5A.26 (2)143.B5 (3)6AB.24 (4)E2F3.2C 2.5 根据ASCII码的表示,查表写出下列字符的ASCII码。 (1)0 (2)9 (3)K (4)G (5)t (6)DEL (7)ACK (8)CR (9)$(10)< 2.6 写出下列十进制数的原码、反码、补码表示(采用八位二进制,最高位为符号位)。 (1)140 (2)52 (3)-26 (4)-127 2.7 已知补码求出其真值。 (1)48H (2)9DH (3)B2H (4)4C10H 2.8 已知某个8位的机器数65H,在其作为无符号数、补码带符号数、BCD码以及ASCII码时分别表示

相关文档
相关文档 最新文档