微型计算机原理及应用课后答案侯晓霞

上传人:ly****51 文档编号:67838271 上传时间:2022-04-01 格式:DOC 页数:38 大小:335.50KB
收藏 版权申诉 举报 下载
微型计算机原理及应用课后答案侯晓霞_第1页
第1页 / 共38页
微型计算机原理及应用课后答案侯晓霞_第2页
第2页 / 共38页
微型计算机原理及应用课后答案侯晓霞_第3页
第3页 / 共38页
资源描述:

《微型计算机原理及应用课后答案侯晓霞》由会员分享,可在线阅读,更多相关《微型计算机原理及应用课后答案侯晓霞(38页珍藏版)》请在装配图网上搜索。

1、.CH01微型计算机概述习题与思考题1 微型计算机由哪些部件组成.各部件的主要功能是什么.解答:2 8086/8088 CPU由哪两部分组成.它们的主要功能各是什么.是如何协调工作的.解答:协调工作过程:总线接口部件和执行部件并不是同步工作的,它们按以下流水线技术原则来协调管理:每当8086的指令队列中有两个空字节,或者8088的指令队列中有一个空字节时,总线接口部件就会自动把指令取到指令队列中。每当执行部件准备执行一条指令时,它会从总线接口部件的指令队列前部取出指令的代码,然后用几个时钟周期去执行指令。在执行指令的过程中,如果必须访问存储器或者输入/输出设备,那么,执行部件就会请求总线接口部

2、件进入总线周期,完成访问内存或者输入/输出端口的操作;如果此时总线接口部件正好处于空闲状态,那么,会立即响应执行部件的总线请求。但有时会遇到这样的情况,执行部件请求总线接口部件访问总线时,总线接口部件正在将某个指令字节取到指令队列中,此时总线接口部件将首先完成这个取指令的操作,然后再去响应执行部件发出的访问总线的请求。当指令队列已满,而且执行部件又没有总线访问请求时,总线接口部件便进入空闲状态。在执行转移指令、调用指令和返回指令时,由于程序执行的顺序发生了改变,不再是顺序执行下面一条指令,这时,指令队列中已经按顺序装入的字节就没用了。遇到这种情况,指令队列中的原有内容将被自动消除,总线接口部件

3、会按转移位置往指令队列装入另一个程序段中的指令。3 8086/8088 CPU中有哪些寄存器.各有什么用途.标志寄存器F有哪些标志位.各在什么情况下置位.解答:寄存器功能数据寄存器AX字乘法,字除法,字I/OBX查表转换CX串操作,循环次数DX字节相乘,字节相除,间接I/O变址寄存器SI源变址寄存器,用于指令的变址寻址DI目的变址寄存器,用于指令的变址寻址指针寄存器SP堆栈指针寄存器,与SS一起来确定堆栈在内存中的位置BP基数指针寄存器,用于存放基地址,以使8086/8088寻址更加灵活控制寄存器IP控制CPU的指令执行顺序PSW用来存放8086/8088CPU在工作过程中的状态段寄存器CS控

4、制程序区DS控制数据区SS控制堆栈区ES控制数据区标志寄存器F的标志位:控制标志:OF、DF、IF、TF;状态标志:SF、ZF、AF、PF、CF。标志寄存器F的各标志位置位情况: CF:进位标志位。做加法时出现进位或做减法时出现借位,该标志位置1;否则清0。PF:奇偶标志位。当结果的低8位中l的个数为偶数时,该标志位置1;否则清0。AF:半进位标志位。在加法时,当位3需向位4进位,或在减法时位3需向位4借位时,该标志位就置1;否则清0。该标志位通常用于对BCD算术运算结果的调整。ZF:零标志位。运算结果各位都为0时,该标志位置1,否则清0。SF:符号标志位。当运算结果的最高位为1时,该标志位置

5、1,否则清0。TF:陷阱标志位(单步标志位)。当该位置1时,将使8086/8088进入单步指令工作方式。在每条指令开始执行以前,CPU总是先测试TF位是否为1,如果为1,则在本指令执行后将产生陷阱中断,从而执行陷阱中断处理程序。该程序的首地址由内存的00004H00007H 4个单元提供。该标志通常用于程序的调试。例如,在系统调试软件DEBUG中的T命令,就是利用它来进行程序的单步跟踪的。IF:中断允许标志位。如果该位置1,则处理器可以响应可屏蔽中断,否则就不能响应可屏蔽中断。DF:方向标志位。当该位置1时,串操作指令为自动减量指令,即从高地址到低地址处理字符串;否则串操作指令为自动增量指令。

6、OF:溢出标志位。在算术运算中,带符号的数的运算结果超出了8位或16位带符号数所能表达的范围时,即字节运算大于十127或小于128时,字运算大于十32767或小于32768时,该标志位置位。4 8086/8088系统中存储器的逻辑地址和物理地址之间有什么关系.表示的范围各为多少.解答:逻辑地址:段地址:偏移地址物理地址:也称为绝对地址,由段基址和偏移量两部分构成。物理地址与系统中的存储空间是一一对应的。逻辑地址与物理地址两者之间的关系为:物理地址段地址16+偏移地址每个逻辑段的地址范围:0000:0000HFFFFH;0001:0000HFFFFH;FFFF:0000HFFFFH;共有232个

7、地址,但其中有许多地址是重叠的(体现出逻辑地址的优势,可根据需要方便地写出逻辑地址,又不影响其准确的物理地址,逻辑地址与物理地址的关系为多对一的关系)。物理地址的地址范围:00000HFFFFFH。5 已知当前数据段位于存储器的A1000H到B0FFFH范围内,问DS=.解答:A1000HA100:0000以A100H为段地址的64K物理地址的范围是:偏移地址为0000HFFFFH,即A100:0000HA100:FFFFHA1000H0000HA1000H0FFFFHA1000HB0FFFH,DSA100H。6 某程序数据段中存有两个字数据1234H和5A6BH,若已知DS=5AA0H,它们

8、的偏移地址分别为245AH和3245H,试画出它们在存储器中的存放情况解答:存放情况如图所示(左右两侧的写法均可):7 8086/8088CPU有哪两种工作模式,它们各有什么特点.解答:为了适应各种不同的应用场合,8086/8088CPU芯片可工作在两种不同的工作模式下,即最小模式与最大模式。所谓最小模式,就是系统中只有一个8086/8088微处理器,在这种情况下,所有的总线控制信号,都是直接由这片8086/8088CPU产生的,系统中的总线控制逻辑电路被减到最少。该模式适用于规模较小的微机应用系统。 最大模式是相对于最小模式而言的,最大模式用在中、大规模的微机应用系统中。在最大模式下,系统中

9、至少包含两个微处理器,其中一个为主处理器,即8086/8088CPU,其它的微处理器称之为协处理器,它们是协助主处理器工作的。8 若8086CPU工作于最小模式,试指出当CPU完成将AH的内容送到物理地址为91001H的存储单元操作时,以下哪些信号应为低电平:M/、/S7、DT/。若CPU完成的是将物理地址91000H单元的内容送到AL中,则上述哪些信号应为低电平。若CPU为8088呢.(略)9 什么是指令周期.什么是总线周期.什么是时钟周期.它们之间的关系如何.解答:指令周期-CPU执行一条指令所需要的时间称为一个指令周期(Instruction Cycle)。总线周期-每当CPU要从存储器

10、或I/O端口存取一个字节称为一次总线操作,相应于某个总线操作的时间即为一个总线周期(BUS Cycle)。时钟周期-时钟周期是CPU处理动作的最小时间单位,其值等于系统时钟频率的倒数,时钟周期又称为T状态。它们之间的关系:若干个总线周期构成一个指令周期,一个基本的总线周期由4个T组成,我们分别称为T1T4,在每个T状态下,CPU完成不同的动作。10 8086/8088 CPU有哪些基本操作.基本的读/写总线周期各包含多少个时钟周期.什么情况下需要插入Tw周期.应插入多少个Tw取决于什么因素.解答:8086/8088CPU最小模式下的典型时序有:存储器读写;输入输出;中断响应;系统复位及总线占用

11、操作。一个基本的CPU总线周期一般包含四个状态,即四个时钟周期;在存储器和外设速度较慢时,要在之后插入1个或几个等待状态;应插入多少个取决于READY信号的状态,CPU没有在状态的一开始采样到READY信号为低电平,就会在和之间插入等待状态,直到采样到READY信号为高电平。11 试说明8086/8088工作在最大和最小模式下系统基本配置的差异。8086/8088微机系统中为什么一定要有地址锁存器.需要锁存哪些信息.(略,见书)12试简述8086/8088微机系统最小模式下从存器储读数据时的时序过程。(略,见书)CH02 80868088指令系统习题与思考题1假定DS=2000H,ES=210

12、0H,SS=1500H,SI=00A0H,BX=0100H,BP=0010H,数据变量VAL的偏移地址为0050H,请指出下列指令源操作数是什么寻址方式.源操作数在哪里.如在存储器中请写出其物理地址是多少.(1)MOV AX,0ABH(2)MOVAX,100H(3)MOVAX,VAL(4)MOVBX,SI(5)MOVAL,VALBX(6)MOVCL,BXSI(7)MOVVALSI,BX(8)MOVBPSI,100解答:(1)MOVAX,0ABH寻址方式:立即寻址;物理地址:无(2)MOVAX,100H寻址方式:直接寻址;源操作数在存储器中;物理地址:DS16+100H2000H*16+100H

13、20100H(3)MOVAX,VAL寻址方式:直接寻址;源操作数在存储器中;物理地址:DS16+VAL2000H*16+0050H20050H(4)MOVBX,SI寻址方式:寄存器间接寻址;源操作数在存储器中;物理地址:DS16+SI2000H*16+00A0H200A0H(5)MOVAL,VALBX寻址方式:变址寻址;源操作数在存储器中;物理地址:DS16+VAL+BX2000H*16+0050H+010020150H(6)MOVCL,BXSI寻址方式:基址加变址寻址;源操作数在存储器中;物理地址:DS16+BX+SI2000H*16+0100H+00A0H201A0H(7)MOVVALSI

14、,BX寻址方式:寄存器寻址;源操作数在寄存器中;物理地址:无(8)MOVBPSI,100寻址方式:立即寻址;物理地址:无2设有关寄存器及存储单元的内容如下:DS=2000H,BX=0100H,AX=1200H,SI=0002H,20100H=12H,20101H=34H,20102H=56H,20103=78H,21200=2AH,21201H=4CH,21202H=0B7H,21203H=65H。试说明下列各条指令单独执行后相关寄存器或存储单元的内容。(1)MOVAX,1800H (2)MOVAX,BX(3)MOVBX,1200H (4)MOVDX,1100BX(5)MOVBXSI,AL (

15、6)MOVAX,1100BXSI解答:题号指令执行结果(1)MOVAX,1800HAX1800H(2)MOVAX,BXAX0100H(3)MOVBX,1200HBX4C2AH(4)MOVDX,1100BXDX4C2AH(5)MOVBXSI,AL20102H00H(6)MOVAX,1100BXSIAX65B7H3假定BX=0E3H,变量VALUE=79H,确定下列指令执行后的结果(操作数均为无符号数。对3、6,写出相应标志位的状态)。(1)ADDVALUE,BX (2)ANDBX,VALUE(3)CMP BX,VALUE(4)XORBX,0FFH(5)DECBX (6)TESTBX,01H解答:

16、题号指令执行结果(1)ADDVALUE,BXBX015CH(2)ANDBX,VALUEBX0061H(3)CMPBX,VALUEBX00E3H(CF=ZF=OF=SF=0,AF=PF=1)(4)XORBX,0FFHBX001CH(5)DECBXBX00E2H(6)TESTBX,01HBX00E3H(CF=ZF=OF=SF=AF=PF=0)4已知SS=0FFA0H,SP=00B0H,先执行两条把8057H和0F79H分别进栈的PUSH指令,再执行一条POP指令,试画出堆栈区和SP内容变化的过程示意图。(标出存储单元的地址)解答:5已知程序段如下:MOVAX,1234HMOVCL,4ROLAX,C

17、LDECAXMOVCX,4MULCX试问:(1)每条指令执行后,AX寄存器的内容是什么.(2)每条指令执行后,CF,SF及ZF的值分别是什么.(3)程序运行结束时,AX及DX寄存器的值为多少.指令执行结果AXCFSFZFMOVAX,1234HAX1234HMOVCL,4AX1234HROLAX,CLAX2341H100DECAXAX2340H100MOVCX,4AX2340H100MULCXAX8D00H,DX=0000H0006写出实现下列计算的指令序列。(假定X、Y、Z、W、R都为字变量)(1)Z=W+(Z+X)(2)Z=W-(X+6)-(R+9)(3)Z=(W*X)/(R+6)(4)Z=

18、(W-X)/5*Y)*2解答:(1)Z=W+(Z+X)题号指令题号指令(1)Z=W+(Z+X)(2)Z=W-(X+6)-(R+9)MOVAX,ZMOVDX,RMOVBX,XADDDX,9MOVCX,WMOVBX,XADDBXADDBX,6ADCCXMOVAX,WMOVZ,AXSUBAX,BXSUBAX,DXMOVZ,AX(3)Z=(W*X)/(R+6)(4)Z=(W-X)/5*Y)*2MOVDX,0MOVAX,WMOVAX,WMOVBX,XMOVBX,XSUBAX,BXMULBXMOVDX,0PUSHAXMOVCL,5MOVAX,RDIVCLADDAX,6MOVBX,YMOVCX,AXMULB

19、XPOPAXMOVCL,2DIVCXMULCLMOVZ,AXMOVZ,AXMOVZ+1,DXMOVZ+1,DX7假定DX=11001B,CL=3,CF=1,试确定下列各条指令单独执行后DX的值。(1)SHRDX,1(2)SHLDL,1(3)SALDH,1(4)SARDX,CL(5)RORDX,CL(6)ROLDL,CL(7)RCRDL,1(8)RCLDX,CL解答:题号指令执行结果(1)SHRDX,1DX=0110 0100 1101 1100(64DCH)(2)SHLDL,1DX=1100 1001 0111 0010(C972H)(3)SALDH,1DX=1001 0010 1011 10

20、01(92B9H)(4)SARDX,CLDX=1111 1001 0011 0111(F937H)(5)RORDX,CLDX=0011 1001 0011 0111(3937H)(6)ROLDL,CLDX=1100 1001 1100 1101(C9CDH)(7)RCRDL,1DX=1100 1001 1101 1100(C9DCH)(8)RCLDX,CLDX=0100 1101 1100 1011(4DCFH)8已知DX=1234H,AX=5678H,试分析下列程序执行后DX、AX的值各是什么.该程序完成了什么功能. MOVCL,4 SHLDX,CL MOVBL,AH SHLBL,CL SH

21、RBL,CL ORDL,BL解答:DX=2345H,AX=6780H。该程序完成的功能如图所示,将DX,AX拼装成双字后,左移四位。9试分析下列程序段:ADDAX,BXJNCL2SUBAX,BXJNCL3JMPSHORTL5如果AX、BX的内容给定如下: AX BX(1)14C6H80DCH(2)B568H54B7H问该程序在上述情况下执行后,程序转向何处.解答:(1)AXAX+BX14C6H+80DCH95A2H;CF0;无进位,转移至L2;(2)方法同(1),略10编写一段程序,比较两个5字节的字符串OLDS和NEWS,如果OLDS字符串不同于NEWS字符串,则执行NEW_LESS,否则顺

22、序执行。解答:编程如下,(说明:左测程序为常规编法,两个字符串在一个数据段中;右测的程序要求OLDS在数据段中,NEWS在附加段中,利用串操作的指令是可行的)LEA SI,OLDS; LEA SI,OLDSLEA DI,NEWS; LEA DI,NEWSMOV CX,5; MOV CX,5NEXT:MOV AL,SI; CLDMOV BL,DI; REPE CMPSBCMP AL,BL; JNZ NEW_LESSJNZ NEW_LESS;INC SI; JMP EXITINC DI; NEW_LESS:LOOP NEXT; EXIT:JMP EXITNEW_LESS:EXIT:11若在数据段中

23、从字节变量TABLE相应的单元开始存放了015的平方值,试写出包含有XLAT指令的指令序列查找N(015)的平方。(设N的值存放在CL中)解答:MOV BX,OFFSET TABLE;LEA BX,TABLEMOV CL,NMOV AL,CLXLAT12有两个双字数据串分别存放在ASC1和ASC2中(低字放低地址),求它们的差,结果放在ASC3中(低字放低地址)。ASC1 DW 578,400ASC2DW694,12ASC3DW.,.解答:编程如下,LEA SI,ASC1LEA DI,ASC2LEA BX,ASC3MOV CX,2CLCNEXT:MOV AX,SIMOV DX,DISBB AX

24、,DXMOV BX,AXINC SIINC SIINC DIINC DIINC BXINC BXLOOP NEXTCH03 汇编语言程序设计习题与思考题1下列语句在存储器中分别为变量分配多少字节空间.并画出存储空间的分配图。VAR1 DB10,2VAR2DW5 DUP(.),0VAR3DBHOW ARE YOU.,$,3 DUP(1,2)VAR4DD-1,1,0解答:字节空间-VAR1:2;VAR2:12;VAR3:19;VAR4:12。存储空间的分配图:DS:0000 0A 02 00 00 00 00 00 0000 00 00 00 00 00 48 4F0010 57 20 41 52

25、 45 20 59 4F55 3F 24 01 02 01 02 010020 02 FF FF FF FF 01 00 0000 00 00 00 002假定VAR1和VAR2为字变量,LAB为标号,试指出下列指令的错误之处。(1)ADDVAR1,VAR2(2)SUBAL,VAR1(3)JMPLABCX(4)JNZVAR1(5) MOV 1000H,100 (6)SHL AL, 4 解答:(1)两个操作数中至少有一个为寄存器;(2)AL为字节,VAR1为字变量,不匹配;(3)中不能用CX;(4)转向地址应为标号;(5)目的操作数的类型不确定;(6)SHL指令中,当所移位数超过1时,必须用CL

26、或CX来取代所移位数。3对于下面的符号定义,指出下列指令的错误。A1DB.A2DB10K1EQU1024(1)MOVK1,AX(2)MOVA1,AX(3)CMPA1,A2(4)K1EQU2048解答:(1)K1为常量,不能用MOV指令赋值;(2)A1为字节,AX为字变量,不匹配;(3)A1未定义,无法做比较指令;(4)K1重新赋值前,必须用PURGE释放。4数据定义语句如下所示:FIRST DB 90H,5FH,6EH,69H SECOND DB 5 DUP() THIRD DB 5 DUP()自FIRST单元开始存放的是一个四字节的十六进制数(低位字节在前),要求:编一段程序将这个数左移两位

27、后存放到自SECOND开始的单元,右移两位后存放到自THIRD开始的单元。(注意保留移出部分)解答:DATA SEGMENTFIRST DB 90H,5FH,6EH,69H SECOND DB 5 DUP() THIRD DB 5 DUP() DATA ENDS CODE SEGMENTASSUME CS:CODE,DS:DATA START:MOV AX,DATAMOV DS,AXLEA SI,FIRSTLEA DI,SECONDMOV CX,2CLC;左移2位MOV AX,SIINC SIINC SIMOV DX,SIPUSH DX PUSH AXROL DX,CL AND DL,03H

28、MOV DI+4,DL ROL AX,CL AND AL,03H MOV BL ,AL POP AX POP DX SHL DX,CLSHL AX,CLOR DL,BLMOV DI,AXMOV DI+2,DX;右移2位,类同左移的方法,略MOV AH,4CHINT 21H CODE ENDS END START5(原14)在当前数据区从400H开始的256个单元中存放着一组数据,试编程序将它们顺序搬移到从A000H开始的顺序256个单元中。解答:DATA SEGMENT ORG 400HDAT1 DB .;256 DUP () ORG 0A000HDAT2 DB .;256 DUP ()DAT

29、A ENDSSTACK SEGMENTSTACK ENDSCODE SEGMENTASSUME DS:DATA,CS:CODE,SS:STACK,ES:DATASTART: MOV AX,DATA MOV DS,AX;CH3-14 LEA SI,DAT1 LEA DI,DAT2 MOV CX,128AGAIN: MOV AL,SI MOV DI,AL INC SI INC DI LOOP AGAIN;CH3-15,将两个数据块逐个单元进行比较,若有错BL=00H,否则BL=FFH LEA SI,DAT1 LEA DI,DAT2 MOV CX,128NEXT: MOV AL,SI MOV BL,

30、DI CMP AL,BL JNZ ERROR INC SI INC DI LOOP NEXT MOV BL,0FFH JMP EXITERROR: MOV BL,00HEXIT: MOV AX,4C00H INT 21HCODE ENDSEND START6试编程序将当前数据区从BUFF开始的4K个单元中均写入55H,并逐个单元读出比较,看写入的与读出的是否一致。若全对,则将ERR单元置0H;如果有错,则将ERR单元置FFH。解答:DATA SEGMENTBUFF DB 1000H DUP()ERR DB DATA ENDSCODE SEGMENT ASSUME CS:CODE,DS:DATA

31、START:MOV AX,DATAMOV DS,AX;将55H依次放入BUFF开始的4K个单元LEA SI,BUFFMOV CX,1000HMOV AL,55HNTXT:MOV SI,ALINC SILOOP NEXT;取出与55H比较,全对则ERR=0,否则ERR=FFHLEA DI,BUFFLEA SI,ERRMOV CX,1000HNEXT1:MOV AL,DIINC DICMP AL,55HJNZ ERROR;若有一个不同,即置ERR=FFHLOOP NEXT1MOV AL,00HMOV SI,AL;全比较完无错,则置ERR=0JMP EXITERROR:MOV AL,0FFHMOV

32、SI,AL;返回DOSEXIT:MOV AH,4CHINT 21HCODE ENDSEND STARTEND7在上题中,如果发现有错时,要求在ERR单元中存放出错的数据个数,则程序该如何修改.解答:DATA SEGMENTBUFF DB 1000H DUP()ERR DW DATA ENDSCODE SEGMENT ASSUME CS:CODE,DS:DATASTART:MOV AX,DATAMOV DS,AX;将55H依次放入BUFF开始的4K个单元LEA SI,BUFFMOV CX,1000HMOV AL,55HNTXT:MOV SI,ALINC SILOOP NEXT;取出与55H比较L

33、EA DI,BUFFLEA SI,ERRMOV DX,0000HMOV CX,1000HNEXT1:MOV AL,DIINC DICMP AL,55HJZ NEXT2;若相同,则比较下一个INC DX;否则将放出错个数的DX加1NEXT2:LOOP NEXT1MOV SI,DXEXIT:MOV AH,4CHINT 21HCODE ENDSEND STARTEND8试编写程序段,完成将数据区从0100H开始的一串字节数据逐个从F0H端口输出,已知数据串以0AH为结束符。(略)9(原24)内存中以FIRST和SECOND开始的单元中分别存放着两个4位用压缩BCD码表示的十进制数, 低位在前。编程序

34、求这两个数的和,仍用压缩BCD码表示, 并存到以THIRD开始的单元。解答:DATA SEGMENTFIRST DW 3412HSECOND DW 7856HTHIRD DB ,DATA ENDSSTACK SEGMENTSTACK ENDSCODE SEGMENTASSUME DS:DATA,CS:CODE,SS:STACK,ES:DATASTART: MOV AX,DATA MOV DS,AX LEA SI,FIRST LEA DI,SECOND LEA BX,THIRD MOV CX,2 CLCAGAIN: MOV AL,BYTE PTRSI MOV DL,BYTE PTRDI ADC

35、AL,DL DAA MOV BYTE PTRBX,AL INC SI INC DI INC BX LOOP AGAIN JC AA MOV BYTE PTRBX,0 JMP EXITAA: MOV BYTE PTRBX,1EXIT: MOV AX,4C00H INT 21HCODE ENDSEND START10(原27)设字变量单元A、B、C存放有三个数,若三个数都不为零,则求三个数的和,存放在D中;若有一个为零,则将其余两个也清零,试编写程序。解答:DATA SEGMENTA DB B DB C DB D DW DATA ENDSSTACK SEGMENTSTACK ENDSCODE SE

36、GMENTASSUME DS:DATA,CS:CODE,SS:STACK,ES:DATASTART: MOV AX,DATA MOV DS,AXLEA SI,ALEA DI,DMOV AL,SICMP AL,00JZ ZEROADC DX,ALLEA SI,BMOV AL,SICMP AL,00JZ ZEROADC DX,ALLEA SI,CMOV AL,SICMP AL,00JZ ZEROADC DX,ALMOV DI,DXJMP EXITZERO:MOV AL,0MOV A,ALMOV B,ALMOV C,ALEXIT: MOV AX,4C00H INT 21HCODE ENDSEND S

37、TART11(16)试编程序,统计由TABLE开始的128个单元中所存放的字符“A”的个数,并将结果存放在DX中。解答:DATA SEGMENTTABLE DB X1,X2,.X128DATA ENDSSTACK SEGMENTSTACK ENDSCODE SEGMENTASSUME DS:DATA,CS:CODE,SS:STACK,ES:DATASTART: MOV AX,DATA MOV DS,AX LEA SI,TABLE MOV DX,0 MOV CX,128AGAIN: MOV AL,SI CMP AL,A JNZ NEXT INC DXNEXT: INC SI LOOP AGAIN

38、 MOV AX,4C00H INT 21HCODE ENDSEND START12试编制一个汇编语言程序,求出首地址为DATA的1000个字数组中的最小偶数,并把它存放于MIN单元中。(方法:利用书上排序的例题做相应的修改即可,略)13在上题中,如果要求同时找出最大和最小的偶数,并把它们分别存放于MAX和MIN单元中,试完成程序。解答:略(方法同第12题)。14(28)在DATA字数组中存放有100H个16位补码数,试编写一程序求它们的平均值,放在AX中,并求出数组中有多少个数小于平均值,将结果存于BX中。(略)15(17)编写一个子程序,对AL中的数据进行偶校验,并将经过校验的结果放回AL中

39、。解答:DATA SEGMENTCOUNT EQU 7DATA ENDSSTACK SEGMENTSTACK ENDSCODE SEGMENTASSUME DS:DATA,CS:CODE,SS:STACK,ES:DATASTART: MOV AX,DATA MOV DS,AX PUSH AX MOV DX,0 MOV CX,COUNTAGAIN: RCR AL,1 JNC L INC DXL: LOOP AGAIN POP AX TEST DX,01 JZ EXIT OR AL,80EXIT: MOV AX,4C00H INT 21H;ANOTHER METHORD JP EXIT OR AL

40、,80HEXIT: MOV AX,4C00H INT 21HCODE ENDSEND START16(18)利用上题的予程序,对DATA开始的256个单元的数据加上偶校验,试编程序。解答:DATA SEGMENTDAT DB .;256 DUP ()RESULT DB .;256 DUP ()NUM EQU 256COUNT EQU 7DATA ENDSSTACK SEGMENTSTACK ENDSCODE SEGMENTASSUME DS:DATA,CS:CODE,SS:STACK,ES:DATASTART: MOV AX,DATA MOV DS,AX LEA SI,DAT LEA DI,R

41、ESULT MOV CX,NUMNEXT: MOV AL,SI CALL SUB1 MOV DI,AL;MOV SI,AL INC SI INC DI LOOP NEXT MOV AX,4C00H INT 21HSUB1 PROC PUSH AX MOV DX,0 MOV CX,COUNTAGAIN: RCR AL,1 JNC L INC DXL: LOOP AGAIN POP AX TEST DX,01 JZ QUIT OR AL,80HQUIT: RETSUB1 ENDPCODE ENDSEND START17(19)试编写程序实现将键盘输入的小写字母转换成大写字母并输出。解答:DATA

42、SEGMENTMESS DB THE INPUT IS NOT CORRECT.,0DH,0AH,$DATA ENDSSTACK SEGMENTSTACK ENDSCODE SEGMENTASSUME DS:DATA,CS:CODE,SS:STACK,ES:DATASTART: MOV AX,DATA MOV DS,AXNEXT: MOV AH,01H INT 21H CMP AL,Q JZ EXIT CMP AL,a JB ERROR CMP AL,z JA ERROR SUB AL,20H MOV AH,02H MOV DL,AL INT 21H JMP NEXTERROR: MOV AH

43、,09H LEA DX,MESS INT 21H JMP NEXTEXIT: MOV AX,4C00H INT 21HCODE ENDSEND START18从键盘接收20个字符,按键入顺序查找最大的字符,并显示输出。解答:DATA SEGMENTDAT DB 20 DUP()DATA ENDSSTACK SEGMENTSTACK ENDSCODE SEGMENTASSUME DS:DATA,CS:CODE,SS:STACK,ES:DATASTART: MOV AX,DATA MOV DS,AX;从键盘接收20个字符,并送DAT中保存LEA SI,DATMOV CX,20NEXT:MOV AH

44、,01HINT 21HMOV SI,ALINC SILOOP NEXT;比较20个字符中的最大字符,并放入AL中 MOV CX,19LEA SI,DATMOV AL,SIINC SINEXT1:CMP AL,SIJAE LLMOV AL,SILL:INC SILOOP NEXT1;将最大的字符的ASCII码由AL送DL显示MOV DL,ALMOV AH,2HINT 21H;返回DOS MOV AX,4C00H INT 21HCODE ENDSEND START19(29)编写汇编程序,接收从键盘输入的10个数,输入回车符表示结束,然后将这些数加密后存于BUFF缓冲区中。加密表为:输入数字:0,

45、1,2,3,4,5,6,7,8,9;密码数字:7,5,9,1,3,6,8,0,2,4解答:DATA SEGMENTBUFF DB 10 DUP()TABLE DB 7,5,9,1,3,6,8,0,2,4DATA ENDSSTACK SEGMENTSTACK ENDSCODE SEGMENTASSUME DS:DATA,CS:CODE,SS:STACK,ES:DATASTART: MOV AX,DATA MOV DS,AX;LEA DI,BUFFNEXT:MOV AH,01HINT 21H;从键盘上接收单个字符CMP AL,0AH;与0AH比,判是否要结束JZ EXITSUB AL,30H;否则

46、,将09的ASCII码转换为十进制数LEA BX,TABLEXLAT;用查表指令进行加密MOV DI,ALINC DIJMP NEXT;退出并返回DOSEXIT: MOV AX,4C00H INT 21HCODE ENDSEND START20(23)有一个100个字节的数据表,表内元素已按从大到小的顺序排列好,现给定一元素,试编程序在表内查找,若表内已有此元素,则结束;否则,按顺序将此元素插入表中适当的位置,并修改表长。(略)21(26)在当前数据段(DS),偏移地址为DATAB开始的顺序80个单元中,存放着某班80个同学某门考试成绩。按要求编写程序:编写程序统计90分;80分89分;70分

47、79分;60分69分,60分的人数各为多少,并将结果放在同一数据段、偏移地址为BTRX开始的顺序单元中。试编程序,求该班这门课的平均成绩为多少,并放在该数据段的AVER单元中。解答:;统计学生成绩DATA SEGMENTDATAB DB X1,X2,.,X80N EQU $-DATABORG 100HBTRX DW 0S8 DW 0S7DW 0S6DW 0S5DW 0ORG 110HAVER DW DATAENDSSTACKSEGMENT STACKSTA DB 20 DUP (0) TOP EQU $STASTACK ENDSCODESEGMENTMAINPROC FARASSUME CS:

48、CODE, DS:DATA, SS:STACKSTART: PUSH DSSUB AX,AX PUSH AXMOV AX,DATAMOV DS,AXMOV CX,NMOV BX,0000HMOV DX,0000HLEA SI,DATAB ;成绩表首地址COMPARE:MOV AL,SICMP AL,60 ;60.JL FIVECMP AX,70 ;70JL SIXCMP AX,80 ;80JL SEVENCMP AX,90 ;90JL EIGHTINC S9JMP CHAEIGHT: INC S8JMP CHASEVEN:INC S7JMP CHASIX:INC S6JMP CHAFIVE:

49、INC S5JMP CHACHA:ADD BX,ALJNC NEXTADC DX,0 NEXT:INC SI ;循环学生人数LOOP COMPAREMOV AX,BXMOV CX,NDIV CXMOV AVER,AXMOV AH,4CHINT 21HRETMAIN ENDPCODE ENDS END STARTCH04 存储系统习题与思考题1存储器的哪一部分用来存储程序指令及像常数和查找表一类的固定不变的信息.哪一部分用来存储经常改变的数据.解答:只读存储器ROM;随机存储器RAM。2术语“非易失性存储器”是什么意思.PROM和EPROM分别代表什么意思.解答:“非易失性存储器”是指当停电后信

50、息会丢失;PROM-可编程序的只读存储器PROM(Programmable ROM),EPROM-可擦除的可编程的只读存储器EPROM(Erasible Programmable ROM)。3微型计算机中常用的存储器有哪些.它们各有何特点.分别适用于哪些场合.解答:(略)4现代计算机中的存储器系统采用了哪三级分级结构,主要用于解决存储器中存在的哪些问题.解答:目前在计算机系统中通常采用三级存储器结构,即使用高速缓冲存储器、主存储器和辅助存储器,由这三者构成一个统一的存储系统。从整体看,其速度接近高速缓存的速度,其容量接近辅存的容量,而位成本则接近廉价慢速的辅存平均价格。三级结构主要用于解决速度

51、、容量和成本的问题。5试比较静态RAM和动态RAM的优缺点,并说明有何种方法可解决掉电时动态RAM中信息的保护。解答:静态RAM-存储一位信息的单元电路可以用双极型器件构成,也可用MOS器件构成。双极型器件构成的电路存取速度快,但工艺复杂,集成度低,功耗大,一般较少使用这种电路,而采用MOS器件构成的电路。静态RAM的单元电路通常是由6个MOS管子组成的双稳态触发器电路,可以用来存储信息“0”或者“1”,只要不掉电,“0”或“1”状态能一直保持,除非重新通过写操作写入新的数据。同样对存储器单元信息的读出过程也是非破坏性的,读出操作后,所保存的信息不变。使用静态RAM的优点是访问速度快,访问周期达2040ns。静态RAM工作稳定,不需要进行刷新,外部电路简单,但基本存储单元所包含的管子数目较多,且功耗也较大,它适合在小容量存储器中使用。动态RAM-

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!