微机原理答案_第1页
微机原理答案_第2页
微机原理答案_第3页
微机原理答案_第4页
微机原理答案_第5页
已阅读5页,还剩47页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、微机原理答案习题 11. 什么是汇编语言,汇编程序,和机器语言?答: 机器语言是用二进制代码表示的计算机能直接识别和执行的一种机器指令的集合。汇编语言是面向及其的程序设计语言。 在汇编语言中, 用助记符代替操作码, 用地址符号或标号代替地址码。 这种用符号代替机器语言的二进制码,就把机器语言编程了汇编语言。使用汇编语言编写的程序, 机器不能直接识别, 要由一种程序将汇编语言翻译成机器语言,这种起翻译作用的程序叫汇编程序。2. 微型计算机系统有哪些特点?具有这些特点的根本原因是什么?答:微型计算机的特点:功能强,可靠性高,价格低廉,适应性强、系统设计灵活,周期短、见效快,体积小、重量轻、耗电省,

2、维护方便。这些特点是由于微型计算机广泛采用了集成度相当高的器件和部件,建立在微细加工工艺基础之上。3. 微型计算机系统由哪些功能部件组成?试说明“存储程序控制”的概念。答:微型计算机系统的硬件主要由运算器、控制器、存储器、输入设备和输出设备组成。“存储程序控制”的概念可简要地概括为以下几点: 计算机(指硬件)应由运算器、存储器、控制器和输入 / 输出设备五大基本部件组成。 在计算机内部采用二进制来表示程序和数据。 将编好的程序和原始数据事先存入存储器中,然后再启动计算机工作,使计算机在不需要人工干预的情况下,自动、高速的从存储器中取出指令加以执行,这就是存储程序的基本含义。 五大部件以运算器为

3、中心进行组织。4. 请说明微型计算机系统的工作过程。答:微型计算机的基本工作过程是执行程序的过程,也就是CPU 自动从程序存放的第 1 个存储单元起,逐步取出指令、分析指令,并根据指令规定的操作类型和操作对象, 执行指令规定的相关操作。 如此重复,周而复始,直至执行完程序的所有指令,从而实现程序的基本功能。5. 试说明微处理器字长的意义。答: 微型机的字长是指由微处理器内部一次可以并行处理二进制代码的位数。它决定着计算机内部寄存器、ALU和数据总线的位数,反映了一台计算机的计算精度, 直接影响着机器的硬件规模和造价。 计算机的字长越大,其性能越优越。在完成同样精度的运算时,字长较长的微处理器比

4、字长较短的微处理器运算速度快。6. 微机系统中采用的总线结构有几种类型?各有什么特点?答:微机主板常用总线有系统总线、I/O总线、ISA总线、IPCI总线、AGP总线、IEEE1394总线、USB总线等类型。7. 将下列十进制数转换成二进制数、八进制数、十六进制数。 (4.75) 10=(0100.11) 2=(4.6) 8=(4.C) 16 (2.25) 10=(10.01) 2=(2.2) 8=(2.8) 16 (1.875) 10=( 1.111) 2=(1.7) 8=( 1.E) 168. 将下列二进制数转换成十进制数。 (1011.011) 2=( 11.6) 10 (1101.01

5、011) 2=(13.58) 10 (111.001) 2=(7.2) 109. 将下列十进制数转换成8421BCD码。 2006=( 0010 0000 0000 0110) BCD 123.456=(0001 0010 0011.0100 0101 0110) BCD10. 求下列带符号十进制数的 8 位基 2 码补码。 +127补= 01111111 -1补= 11111111 -128补= 10000000+1补=0000000111. 求下列带符号十进制数的 16位基 2码补码。 +655补= 01111 -1补=1111111111111110 -3212补=11110 +100补

6、=001001. 8086 CPUS内部结构上由哪几部分组成?各部分的功能是什么?答: 8086 CPU 内部由两大独立功能部件构成,分别是执行部件和总线接口部件。 执行部件负责进行所有指令的解释和执行, 同时管理有关的寄存器。总线接口部件是CPU在存储器和I/O设备之间的接口部件,负责对全部引脚的操作。2 .简述8086 CPU的寄存器组织。答:8086 CPU内部共有14个16位寄存器,按用途可分为数据寄存器,段寄存器, 地址指针与变址寄存器和控制寄存器。数据寄存器包括累加器,基址寄存器,计数器,和数据寄存器。段寄存器用来存放各分段的逻辑段基值, 并指示当前正在使用的 4 个逻辑段。 地址

7、指针与变址寄存器一般用来存放主存地址的段内偏移地址, 用于参与地址运算。控制寄存器包括指令寄存器和标识寄存器。3 .试述8086 CPUte志寄存器各位的含义与作用。答: 标志寄存器是16 位的寄存器, 但实际上 8086 只用到 9 位, 其中的 6 位是状态标识位, 3 位是控制标识位。 状态标志位分别是CF, PF,AF, ZF, SF,和OF;控制标志位包括 DF, IF, TF。CF:进位标志位。算数运算指令执行后,若运算结果的最高位产生进位或借位,则CF=1,否则CF=QPF:奇偶标志位。反应计算结果中1的个数是偶数还是奇数。若运算结果的低8位中含有偶数个1,则PF=1;否则PF=

8、0.AF: 辅助进位标志。 算数运算指令执行后, 若运算结果的低4 位向高4位产生进位或借位,则 AF=1;否则AF=0.ZF:零标志位。若指令运算结果为 0,则ZF=1;否则ZF=(1SF:符号标志位。它与运算结果最高位相同。OF:溢出标志位。当补码运算有溢出时, OF=1;否则OF=&DF:方向标志位。用于串操作指令,指令字符串处理时的方向。IF:中断允许标志位。用来控制 8086是否允许接收外部中断请求。TF:单步标志位。它是为调试程序而设定的陷阱控制位。4. 8086 CPU犬态标志和控制标志有何不同?程序中是怎样利用这两类标识的? 8086 的状态标志和控制标识分别有哪些?答

9、: 状态标志位反应了当前运算和操作结果的状态条件, 可作为程序控制转移与否的依据。它们分别是 CF, PF, AF, ZF, SF5和OF。控制标志位用来控制 CPU的操作,由指令进行置位和复位,控制标志位包括DF, IF, TF。5. 将 1001 1100和 1110 0101 相加后, 标识寄存器中 CF, PF, AF, ZF, SF,OF各为何值?答:CF=1, PF=1, AF=1, ZF=0, SF=1, OF=06. 什么是存储器的物理地址和逻辑地址?在8086 系统中, 如何由逻辑地址计算物理地址? 答: 逻辑地址是思维性的表示, 由段地址和偏移地址联合表示的地址类型叫逻辑地

10、址。 物理地址是真实存在的唯一地址, 指的是存储器中各个单元的单元号。在8086系统中,物理地址二段地址x 10H+偏移地址7. 段寄存器CS=1200H, 指令指针寄存器IP=4000H, 此时, 指令的物理地址为多少?指向这一地址的 CS指和IP值是唯一的吗?答:此指令的物理地址=1200HX 10H+4000H=16000H并且指向这一 物理地址的CS值和IP值并不是唯一的。8. 在 8086 系统中,逻辑地址 FFFF 0001, 00A2: 37F和 B800: 173F 的物理地址分别是多少?答:逻辑地址FFFF: 0001 00A2: 3TF B800: 173F物理地址 FFF

11、F1H00D9FH B973FH9. 在 8086 系统中,从物理地址388H 开始顺序存放下列 3 个双字节的数据 651AH, D761H和 007BH,请问物理地址 388H, 389H, 38AH,38BH, 38CH和38DH 6个单元中分别是什么数据?答: (388H) =1AH,(389H) =65H,(38AH)=61H,(38BH) =DTH,(38CH) =7BH, ( 38DH) =00H10. 8086微处理器有哪几种工作模式?各有什么特点?答: 8086 微处理器有最大和最小工作模式。在最小模式下:8086 CPU直接产生全部总线控制信号(DT/R, DENALE,

12、M/IO)和命令输出信号(RD, WR, INTA)并提出请求访问总线 的逻辑信号HOLD, HLDA。在最大工作模式下, 必须配置 8288 总线控制器, 并且根据 8086 提供的状态信号S2, S1, S0, 输出读写控制命令,可以提供灵活多变的系统配置,以实现最佳的系统性能。11. 简述 8086 引脚信号中 M/IO, DT/R, RD, WR, ALE DEN和 BHE 的作用。答:M/IO:输出信号,高电平时,表示CPU与存储器之间数据传输; 低电平时,表示CPU与I/O设备之间数据传输。DT/R控制其数据传输方向的信号。DT/R=1时,进行数据发送;DT/R=0 时,进行数据接

13、收。RD: CPU的读信号,RD=0时,表示8086为存储口或I/O端口读操作。WR: CPU的写信号,WR =0时,表示8086为存储口或I/O端口写操 作。ALE地址存锁信号,在T1能时刻有效。DEM数据选通信号,当DEN有效时,表示允许传输。BHE数据总线允许信号,与 A0组合使用,表示是否访问奇地址字节。12. 简述 8086 读总线周期和写总线周期和引脚上的信号动尖态变化过程。8086 的读周期时序和写周期时序的区别有哪些?答:在 8086 读周期内,有关总线信号的变化如下: M/ :在整个读周期保持有效,当进行存储器读操作时, M/ 为高电平;当进行I/O 端口读操作时, M/ 为

14、低电平。A19/S6A16/S3:在T1期间,输出CPU要读取的存储单元或I/O 端口的地址高4位。T2T4期间输出状态信息S6-S3/S7:在T1期间,输出BHE有效信号(为低电平),表示高8位数据总线上的信息可以使用, 信号通常作为奇地址存储体的体选信号(偶地址存储体的体选信号是最低地址位A0)。 T2 T4 期间输出高电平。AD15AD0:在T1期间,输出CPU要读取的存储单元或I/O端口的 地址A15A0。T2期间为高阻态,T3T4期间,存储单元或I/O端 口将数据送上数据总线。CPU从AD15AD0上接收数据。ALE在T1期间地址锁存有效信号,为一正脉冲,系统中的地址锁 存器正是利用

15、该脉冲的下降沿来锁存 A19/S6A16/S3, AD15AD0中20 位地址信息以及 : T2 期间输出低电平送到被选中的存储器或 I/O 接口,注意,只有被地址信号选中的存储单元或I/O端口,才会被RD信号从中读出数据(数据送上数据总线AD15AD0)。 DT/ :在整个总线周期内保持低电平,表示本总线周期为读周期,在接有数据总线收发器的系统中,用来控制数据传输方向。:在T2T3期间输出有效低电平,表示数据有效,在接有数据总线收发器的系统中,用来实现数据的选通。总线写操作的时序与读操作时序相似,其不同处在于:AD15AD0:在T2T4期间送上欲输出的的数据,而无高阻态。:从T2T4,引脚输

16、出有效低电平,该信号送到所有的存储器和 I/O 接口。注意,只有被地址信号选中的存储单元或 I/O 端口才会被 信号写入数据。 DT/ :在整个总线周期内保持高电平,表示本总线周期为写周期,在接有数据总线收发器的系统中,用来控制数据传输方向。习题 31. 假定(DS) =2000H, (ES) =2100H, (SS) =1500H, (SI) =00A0H,(BXQ =0100H, (BP) =0010H,数据变量 VAL 的偏移地址为 0050H,请指出下列指令原操作数是什么寻址方式,其物理地址是多少?(1) MOV AX, 0ABH (2) MOV AX, 100H(3) MOVAX,

17、VAL(4) MOVBX, SI(5) MOVAL, VALBX(6) MOVCL, BXSI(7) MOVVALSI, BX(8) MOVBPSI, 100答: (1) 立即数寻址,物理地址:无 直接寻址,物理地址=2000HX 10H+100H=20100H 直接寻址,物理地址=2000HX 10H+0050H=20050H 寄存器间接寻址,PA=2000H< 10H+00A0=200A0H(5)相对寄存器寻址,PA=2000H< 10H+ (0050+0100H) =20150H(6)基址加变寻址,PA=2000HX 10H+ (0100H+00A0H)=201A0H(8)

18、寄存器寻址,无 PA(9) 立即数寻址,无 PA2.已知(S9 =0FFA0H (SB =00B0H,先执行两条把 8057H 和 0F79H 分别进栈的PUSH指令,再执行一条POP指令,试画出堆栈区和SP 内容变化的过程示意图。答:“8057H”进栈,贝U SP自动从00B0H指向00B2H, “0F79HT进栈,贝U SP自动从00B2H指向00B4H;执行一条POP指令,“0F79HT被弹出栈,SP从00B4H指向00B2H。图略3. 设有关寄存器及存储单元的内容如下:(DS)=2000H, (BX)=0100H, (AX)=1200H, (SI)=0002H, (20100H)=12

19、H, (20101H)=34H,(20102H)=56H,(20103H)=78H,(21200H)=2AH,(21201H)=4CH, (21202H)=0B7H, (21203H)=65H.试说明下列各条指令单独执行后相关寄存器或存储单元的内容。(1) MOV AX, 1800H (2) MOV AX, BX(3) MOV BX, 1200H (4) MOV DX, 1100BX(5) MOV BXSI, AL (6) MOV AX, 1100BXSI答: (1) (AX)=1800H (2) (AX)=0100H (3) (BX)=4C2AH(4) (DX)=4C2AH (5) (201

20、02H)=00H (6) (AX)=65B7H4. 写出实现下列计算的指令序列。(1) Z=W+(X+Z) (2) Z=W-(X+6)-(R+9)答: (1) MOV AX, ZADD AX, XADD AX, WMOV Z, AX(2) MOV AX, WADD X, 6SUB AX, XADD R, 9SUB AX, RMOV Z, AX5 .若在数据段中从字节变量 TABLE相应的单元开始存放了 015的 平方值,试写出包含XLAT指令的指令序列查找N (015)中的某个 平方数。答: LEA BX, TABLEMOV AL, CL XLAT6 . 写出实现下列计算的指令序列。(1) Z

21、=(W*X)/(R+6) (2) Z=(W-X)/5*Y)*2答: (1) MOV AX, WIMUL XADD R, 6IDIV RMOV Z, AX(2) MOV AX, WSUB AX, XMOV BL, 5IDIV BLCBWIMUL YMOV BX, 2IMUL BXMOV Z, AX7.假定(DX)=11001B,CL=3 CF=1,试确定下列各条指令单独执行后DX的值。(1) SHR DX, 1(2)SHLDL, 1(3) SAL DH, 1 (4) SAR DX, CL(5) ROR DX, CL (6) ROL DL, CL (7) RCR DL, 1 (8) RCL DX,

22、 CL答: (1) (DX)=0110 0100 1101 1100B (2) (DX)=1100 1001 0111 0010B(3) (DX)=1001 0010 1011 1001B (4) (DX)= 1111 1001 0011 0111B(5) (DX)= 0011 1001 0011 0111B (6)(DX)= 0100 1101 1100 1110B7. ) (DX)= 1110 0100 1101 1100B (8) (DX)= 1001 0011 0111 0011B8. 已知程序段如下:MOV AX, 1234HMOV CL, 4ROL AX, CLDEC AXMOV

23、CX, 4MUL CXINT 20H试问:(1)每条指令执行后,AX寄存器的内容是什么? ( 2)每条指令执行后,CF, SF 及 ZF 的值分别是什么?( 3 )程序运行结束后,AX 及 DX 寄存器的值为多少?答: MOV AX, 1234H(AX)=1234H, CF=,0 SF=0, ZF=0MOV CL, 4ROL AX,CLDEC AXMOV CX,4MULL CXINT 20H(AX)=2341H,CF=,1 SF=0, ZF=0(AX)=2340H,CF=,1 SF=0, ZF=0(AX)=8D00H, CF=,0 SF=1, ZF=0结束后, (DX)=0000H, (AX)

24、=8000H9. 试分析下列程序段:ADD AX, BXJNC L2SUB AX, BXJNC L3JMP SHORTL5如果 AX, BX 的内容给定如下:AXBX(1) 14C6H80DCH(2) B568H54B7H问该程序在上述情况下执行后,程序转向何处。答:(1)转到L2处(2)转到L3处习题 41 下列语句在存储器中分别为变量分配多少字节空间?并画出存储空间的分配图。VAR1 DB 10, 2VAR2 DW 5 DU(?)P, 0VAR3 DB HOW ARE YO?U , 3 DUP(1 , 2)VAR4 DD -,1 1, 0答:字节空间:VAR1: 2;VAR2: 12;VA

25、R3: 13;VAR4: 8。存储空间的分配图:2 假定VAR1 和 VAR2 为字变量, LAB 为标号,试指出下列指令的错误之处。1) ADD VAR1, VAR22) SUB AL, VAR13) JMP LABCX4) JNZ VAR15) MOV 1000H, 1006) SHL AL, 4答: (1) 在算术运算指令中,两个操作数不能同时为存储器寻址方式(2) AL 为字节, VAR1 为字变量,字长不相等;(3) 寄存器相对寻址方式, 只能使用基址或变址寄存器, 不能使用 CX寄存器。(4) 转向地址应为标号,不能是变量;(5) 目的操作数的类型不确定;(6) SHL指令中,当所

26、移位数超过1时,必须用CL取代所移位数。3对于下面的符号定义,指出下列指令的错误。A1 DB ?A2 DB 10K1 EQU 10241) MOV K1, AX (2) MOV A1, AX3 ) CMP A1, A2 ( 4) K1 EQU 2048 答: (1)K1 为常量,不能用 MOV 指令赋值;(2)A1 为字节, AX 为字变量,不匹配;(3)A1 未定义,无法做比较指令;(4)K1重新赋值前,必须用PURGE释放。4 数据定义语句如下所示:FIRST DB 90,H 5FH, 6EH, 69HSECOND DB 5 DUP(?)THIRD DB 5 DUP(?)自FIRST单元开

27、始存放的是一个四字节的十六进制数(低位字节在前), 要求 :编一段程序将这个数左移两位后存放到自SECON计始的单元,右移两位后存放到自THIRD开始的单元。(注意保留移出部分)答:DATA SEGMENTFIRST DB 90H, 5FH, 6EH, 69HSECOND DB 5 DUP(?)THIRD DB 5 DUP(?)FORTH DB 4 DUP (?)DATA ENDSCODE SEGMENTASSUME C:S CODE, DS: DATASTAR:T MOV AX, DATAMOV DS, AXLEA SI, FIRSTLEA DI, SECONDMOV CX, 2CLC;左移

28、 2 位MOV AX, WORD PTR SI据INC SIINC SIMOV DX, WORD PTR SI据PUSH DXPUSH AXROL DX, CL;AX=5F90H为低十六位数;DX=696EH为高十六位数;保存原有的高十六位数据;保存原有的低十六位数据; 将高位数据不带进位循环左移两位, 即高 2 位数据在 DL 的低 2 位AND DL, 03H ;让 DL 中仅保存移出的高 2 位数据MOV DI+4 , DL;将移出的高2位数据放入SECOND中的最高单元中ROL AX, CL;将低位数据不带进位循环左移两位,即 AX 的高 2位在 AL 的低 2 位AND AL, 03

29、H;让AL中仅保存移出的AX高2位数据MOV BL , AL;将AL中的数据放入 BL中保存POP AX;弹出原有的低十六位数据POP DX;弹出原有的高十六位数据SHL DX, CL;将高位数据算术逻辑左移2位SHL AX, CL;将低位数据算术逻辑左移2位OR DL, BL;将AX中移出的高2位数据放入DX的低2位MOV WORD PTR DI , AXMOV WORD PTR DI+2 , DX;右移 2 位LEA SI, FIRSTLEA DI, THIRDMOV CX, 2CLCMOV AX WORD PTR SI ; AX=5F90H 为低十六位数据INC SIINC SIMOV

30、DX, WORD PTR SI ; DX=696EH为高十六位数据PUSH DX;保存原有的高十六位数据PUSH AX;保存原有的低十六位数据ROR AX, CL将低位数据不带进位循环右移两位,即低 2位数据在 AH 的高 2 位AND AH, 0C0H;让AH中仅保存移出的低2位数据PUSH CXMOV CX, 6SHRAH, CLPOP CXMOV DI , AH ;将移出的低2 位数据放入 THIRD 中的最低单元中ROR DX, CL; 将低位数据不带进位循环左移两位, 即 AX 的高 2 位在 AL 的低 2 位ANDDH, 0C0H;让 DH 中仅保存移出的 DX 低 2 位数据M

31、OVBL , DH;将 DH 中的数据放入BL 中保存POPAX;弹出原有的低十六位数据POPDX;弹出原有的高十六位数据SHRDX, CL;将高位数据算术逻辑左移 2 位SHRAX, CL;将低位数据算术逻辑左移 2 位OR AH, BLDX 中移出的低2 位数据放入 AX 的高2 位MOV WORD PTR DI+1 , AXMOV WORD PTR DI+3 , DX;求补LEA SI, FIRSTLEA DI, FORTHMOV AX, WORD PTR SI ; AX=5F90H 为低十六位数据INC SIINC SIMOV DX, WORD PTR SI ; DX=696EH为高十

32、六位数据;将低十六位取反;将高十六位按位取反;低位加 1 ,即可为原数的求补;高位加低位加法时的进位AXXOR AX, 0FFFFHXOR DX, OFFFFHCLCADD AX, 01HADC DX, 0MOV WORD PTR DI ,MOV WORD PTR DI+2 , DXMOV AH, 4CHINT 21HCODE ENDSEND START5.试编程序将内存从40000H至U 4BFFF用每个单元中均写入55H,并再逐个单元读出比较,看写入的与读出的是否一致。若全对,则将AL置7EH;只要有错,则将AL置81H。答:DATA SEGMENTDA1 DB 55HCODE SEGME

33、NTASSUME CS:CODE,DS:DATASTART:MOV AX,4000HMOV DS,AXMOV CX,0C000HMOV BX,0000HMOV AH,55HNEXT1: MOV byte ptrBX,AHINC BXLOOP NEXT1MOV BX,0000HMOV CX,0C000HMOV AL,81HNEXT2: MOV AH, BXCMP AH,55HJNZ EXITINC BXLOOP NEXT2MOV AL,7EHEXIT:MOV AH,4CHINT 21HCODE ENDSEND START6. 在当前数据段4000H 开始的128个单元中存放一组数据,试编程序将它

34、们顺序搬移到 A000H 开始的顺序 128 个单元中,并将两个数据块逐个单元进行比较;若有错将BL置00H;全对则将BL置FFH,试编程序。答:DATA SEGMENTORG 400HDA1 DB 128 DUP(?)ORG 0A00HDA2 DB 128 DUP(?)DATA ENDSCODE SEGMENTASSUME CS:CODE,DS:DATA,ES:DATASTART: MOV AX,DATAMOV DS,AXLEA SI,DA1LEA DI,DA2MOV CX,128AGAIN: MOV AL,SIINC SIINC DILOOP AGAINLEA SI, DA1LEA DI,

35、 DA2MOV CX,128NEXT: MOV AL,SIMOV BL,DICMP AL,BLJNZ ERRORINC SIINC DIMOV BL,0FFHLOOP NEXTJMP EXITERROR: MOV BL,00HEXIT: MOV AH,4CHINT 21HCODE ENDSEND START7. 设变量单元A、 B、 C 存放有3 个数,若 3 个数都不为零,则求3个数的和,存放在D 中 ; 若有一个为零,则将其余两个也清零,试编写程序。答:DATA SEGMENTA DB ?B DB ?C DB ?DATA ENDSCODE SEGMENTASSUME CS:CODE,DS:

36、DATASTART: MOV AX,DATAMOV DS,AXCMP A,00HJNZ LP1MOV B,0MOV C,0JMP LP4LP1: CMP B,00HJNZ LP2MOV A,0MOV C,0JMP LP4LP2: CMP C,00HJNZ LP3MOV A,0MOV B,0JMP LP4LP3: MOV AL,AADD AL,BADD AL,CMOV AH,4CHLP4: INT 21HCODE ENDSEND START8. 有一个 100 个字节的数据表,表内元素已按从大到小的顺序排列好,现给定一元素,试编程序在表内查找,若表内已有此元素,则结束 ; 否则,按顺序将此元素插

37、入表中适当的位置,并修改表长。答:DATA SEGMENTBUFF DB 100 DUP(?)DA1 DB (?)LENGTH DB 0DATA ENDSCODE SEGMENTASSUME CS:CODE,DS:DATASTART: MOV AX,DATAMOV DS,AXMOV SI,0MOV AL,DA1MOV CX,100FIND0: CMP BUFFSI,ALJZ EXITINC SILOOP FIND0MOV DI,99MOV SI,0COMPARE: CMP BUFFDI,ALJG INSERTMOV BL,BUFFDIMOV BUFFDI+1,BLDEC DICMP DI,SI

38、JNL COMPAREJMP EXITINSERT: MOV BUFFDI+1,ALMOV LENGTH , 101EXIT: MOV AH,4CHINT 21HCODE ENDSEND START9.内存中以FIRS书口 SECONDS始的单元中分别存放着两个 16位组合的十进制(BCD码)数,低位在前。编程序求这两个数的组合的十进制和,并存到以THIRD#始的单元。答:DATA SEGMENT31 / 59FIRST DD 34341212HSECOND DD 78785656HTHIRD DB ?,?,?,?DATA ENDSCODE SEGMENTASSUME CS:CODE,DS:D

39、ATASTART:MOV AX,DATAMOV DS,AXLEA SI,FIRSTLEA DI,SECONDLEA BX,THIRDMOV CX,4CLCAGAIN: MOV AL,BYTE PTRSIMOV DL,BYTE PTRDIADC AL,DLDAAMOV BYTE PTRBX,ALINC DIINC BXLOOP AGAINJC AAMOV BYTE PTRBX,0JMP EXITAA: MOV BYTE PTRBX,1EXIT: MOV AH,4CHINT 21HCODE ENDSEND START10. 编写一段程序,接收从键盘输入的 10 个数,输入回车符表示结束,然后将这些

40、数加密后存于 BUFF缓冲区中。加密表如下:输入数字 : 0, 1, 2, 3, 4, 5, 6, 7, 8, 9; 密码数字 : 7, 5, 9, 1,3, 6, 8, 0, 2, 4。答:DATASEGMENTMITAB DB &#39;7591368024&#39;CONTEQU$-MITABBUFFDB10 DUP (?,) &#39;$&#39;YUANWEN DB 10 DUP (?,) &#39;$&#39;33 / 59DATA ENDSCODE SEGMENTASSUME CS: CODE DS: DATASTAR:T MOVA

41、X, DATAMOVDS,AXMOVSI,0MOVCX,CONTINPUT: MOVAH, 1INT21HCMP AL, 13JZ EXITAND AL, 0FHMOVYUANWENSI , ALINC SILOOP INPUTEXIT : LEABX, MITABMOV CX, SIMOV SI, 0JIAMI: MOV AL, YUANWENSIXLAT MITABLOOP JIAMIMOV AH, 4CHINT 21HCODE ENDSEND START11 .试编程序,统计由40000H开始的16K个单元中所存放的字符“A”的个数,并将结果存放在DX 中。答:DATA SEGMENTD

42、A1 DB &#39;A&#39;BUFF DB 4000H DUP(?)DATA ENDSCODE SEGMENTASSUME CS:CODE,DS:DATASTART: MOV AX,4000HMOV DS,AXMOV BX,0MOV CX,4000HFIND:MOV AL,BXMOV BL,DA135 / 59CMP AL,BLJNZ NEXTINC DXNEXT:INC SILOOP FINDMOV AH,4CHINT 21HCODE ENDSEND START12 .在当前数据段(DS),偏移地址为DATA所始的顺序80个单元中,存放着某班80 个同学某门考试成绩。按

43、如下要求编写程序: 编写程序统计A 90分;80分89分;70分79分;60分69分,<60分的人数各为多少,并将结果放在同一数据段、偏移地址为BTRX 开始的顺序单元中。(2) 试编程序,求该班这门课的平均成绩为多少,并放在该数据段的AVE弹元中。答:DATA SEGMENTBUFF DW 80 DUP(?)DA9 DB 0DA8 DB 0DA7 DB 0DA6 DB0DA5 DB 0AVER DB 0DATA ENDSCODE SEGMENTASSUME CS:CODE,DS:DATASTART: MOV AX,DATAMOV DS,AXMOV CX,80COMPARE: MOV B

44、X,0CMP BUFFBX,90JB LP8INC DA9JMP NEXTLP8: CMP BUFFBX,80JB LP7INC DA837 / 59JMP NEXTLP7: CMP BUFFBX,70JB LP6INC DA7JMP NEXTLP6: CMP BUFFBX,60JB LP5INC DA6JMP NEXTLP5: INC DA5JMP NEXTNEXT: INC BXLOOP COMPAREMOV CX,80XOR AX,AXMOV BX,00SUM: ADD AX,BUFFBXINC BXLOOP LP1MOV CL,80DIV CLMOV AH,4CHINT 21HCODE

45、 ENDSEND START13. 编写一个子程序,对AL 中的数据进行偶校验,并将经过校验的结果放回AL 中。答:JIOU PROCPUSH CXPUSH BXXOR AH, AHPUSH AXMOV CL, 7LOOP1: SAR AL, 1ADC AH, 0LOOP LOOP1MOV AL, AHXOR AH, AHMOV BL, 2DIV BLMOV BL, AH39 / 59POP AXROR BL, 1OR AL, BLPOP BXPOP CXRETJIOU ENDP14. 利用上题的子程序,对80000H 开始的 256 个单元的数据加上偶校验,试编程序。CODE SEGMENT

46、ASSUME CS: CODESTART : MOV AX, 8000HMOV DS, AXMOV SI, 0MOV CX, 256LP: MOV AL, SICALL JIOUMOV SI, ALINC SILOOP LPINT 21HJIOU PROCPUSH CXPUSH BXXOR AH, AHPUSH AXMOV CL, 7LOOP1: SAR AL, 1ADC AH, 0LOOP LOOP1MOV AL, AHXOR AH, AHMOV BL, 2DIV BLMOV BL, AHPOP AXROR BL, 1OR AL, BLPOP BXPOP CXRETJIOU ENDPCODE

47、 ENDSEND START习题 51 .试述DRAM的工作特点;与SRAM相比有什么长处和不足之处; 说明它的使用场合。答: DRAM, 动态随机存取存储器, 需要不断的刷新, 才能保存数据。而且是行列地址复用的,许多都有页模式。SRAM,静态的随机存取存储器,加电情况下,不需要刷新,数据不会丢失,而且一般不是行列地址复用的。与SRAM相比,DRAM价格便宜、速度慢、容量大,主要用来做主存 储器,存储程序和数据;而SRAM主要用在Cache等对速度要求高的 情况。2 .试述DRAM刷新过程和正常读/写过程的区别。答:刷新是以行为单位进行,且刷新过程中不能进行读写操作。3 . 设有一个具有20

48、 位地址和 32 位字长的存储器,问:( 1) 该存储器能存储多少个字节的信息?(2)如果存储器由512K*8位SRAM芯片组成,需要多少片?( 3) 需要多少位作芯片选择?答:(1)该存储器能存储4MB 的信息。2 2) 需要 8 片 512K*8 位的芯片。3 3) 需要 1 位做芯片选择。4 .对于8Kx 8位RAM组成的存储器系统,若某组的起始地址为 08000H,则其末地址为多少?答:末地址为 9FFF.5 .在8088最大方式系统总线上扩充设计 4K字节的SRAM存储器电 路。SRAM芯片选用Intel 2114,起始地址从0000H。试画出此存储器 电路与系统总线的连接图。答:系

49、统容量为4K*8bit,芯片容量为1K*4bit,所以一共需要8片芯 片连接图如下:6 . 在 8088 系统总线上扩充设计8K 的字节的 SRAM 存储器电路。SRAM 芯片选用 Intel 6264,起始地址从04000H 开始,译码器电路74LS138.( 1) 计算此 RAM 存储区的最高地址是多少。( 2) 画出此存储器电路与系统总线的连接图。( 3) 编写程序实现对此存储区域进行自检。答: ( 1)最高地址是05FFFH。( 2)( 3) MOV DX, 0FFE2HL1: IN AL, DXTEST AL, 01HJZ L1MOV AX, 1000HMOV DS, AXMOV D

50、X, 2000HMOV CX, 100MOV DX, 0FFE0HL2: IN AL, DXMOV DX, ALINC BXLOOPN L27.在8086最小方式系统总线上扩充设计16K字节的SRAM存储器电路,SRAM芯片选用Intel 6264,起始地址从04000H开始,译码器电路采用 74LS138.( 1) 计算此 RAM 存储区域的最高地址是多少( 2) 画出此存储器与总线的连接图。答: (1) 07FFFH(2)习题 61. 什么是接口?接口的功能是什么?答:位于主机与外设之间,用来协助完成数据传送和控制任务的逻辑电路称为接口电路,接口电路对输入/ 输出过程起缓冲和联络作用。接口

51、的功能是有, 数据缓冲功能, 联络功能, 寻址功能, 预处理功能,中断管理功能。2. 计算机对 I/O 端口编址时通常采用哪两种方法?在 8086 系统中,用哪种方法进行编址?答: I/O 端口和存储器统一编址; I/O 端口单独编址。 8086 系统采用I/O 端口单独编址方式。3. CPU和输入/输出设备之间传送的信息有哪几类?答 : 数据信息,控制信息,与状态信息。4. 简述CPU与外设进行数据交换的几种常用方式.答 : 程序控制方式: 特点是依靠程序的控制来实现主机和外设的数据传送 ,可分为无条件传送方式和查询方式.中断控制方式:每次输入和输出一个数据,CPU都要检查外设的状态。直接存

52、储器存取控制方式: cpu 不参加数据传送,而是由 DMA 控制器来实现内存与外设,外设与外设之间的直接传递。通道方式: 可以实现对外围设备的统一管理和外围设备与内存之间的数据传送。外围处理机方式:由PPU独立于主机工作,减少了 CPU控制外设的负担。5无条件传送方式适用哪些场合?查询方式原理怎样?主要用在什么场合?答:无条件传送适用于简单的输入/ 输出设备,CPU 可以随时读取或接受状态。这些信号变化缓慢,当需要采集数据时,无需检查端口,就可以立即采集数据,直接用输入/ 输出指令完成。无条件传送方式主要用于控制CPU与低俗I/O接口之间的信息交换7查询式传送方式有什么优缺点?中断方式为什么能

53、弥补查询方式的缺点?答:查询传送方式CPU 通过程序不断查询相应设备的状态,状态不符合要求,则CPU需要等待;只有当状态信号符合要求时,CPU才能进行相应的操作。 中断方式提高了计算机系统中信息处理的并行和处理器效率,中断可以实现同步操作,实时处理等功能。8. 8088/8086 中断向量表的作用是什么?答: 中断向量表建立了不同的中断源与其相应的中断服务程序首地址之间的联系,它是CPU 在响应中断时可以依据中断类型码自动转向中断服务程序。9. 什么叫中断向量?它放在哪里?对于1CH 的中断向量在哪里?如果 1CH 的中断程序从5110H 开始: 2030H 开始,则中断向量应该怎样存放?答:中断向量即用来提供中断入口地址的一个指针。10. 8259中IRR, IMR, IS审个寄存器的作用是什么?答:中断请求寄存器IRR8259A有8条外部中断请求输入信号线IR0-IR7,每一条请求线上有一个相应的触发器来保存请求信号,它们形成了中断请求寄存器IRR

温馨提示

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

评论

0/150

提交评论