微机原理期末复习.doc_第1页
微机原理期末复习.doc_第2页
微机原理期末复习.doc_第3页
微机原理期末复习.doc_第4页
微机原理期末复习.doc_第5页
已阅读5页,还剩9页未读 继续免费阅读

下载本文档

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

文档简介

一、回答问题问题1:8086的存储器为什么要进行分段?答:8086的地址总线AB有20根地址线,意味着存储器每个存储单元的地址由20位二进制数构成。而8086内部用来存放地址信息的寄存器只有16位,出现了矛盾,为解决这个问题,8086采取了存储器分段的方式。由于16位二进制地址可寻址范围是64KB而1MB的存储空间可以在逻辑上分为16个段每段大小是64KB,因此可以用段地址(也称为段基址)给每个段编号,每个段内的地址单元用偏移地址编号。问题2:什么是物理地址?什么是逻辑地址?请说明二者的关系。答:物理地址共有20位,对应一个存储单元的实际地址,物理地址与存储单元是一一对应关系。逻辑地址则由段地址和偏移地址组成是指令中引用的形式地址。一个逻辑地址只能对应一个物理地址,而一个物理地址可以对应多个逻辑地址。(2000:0202H、2010:0102H、)。段地址16位,即存储单元所在逻辑段的编号,通常存放在对应的段寄存器中,偏移地址为16位,存储单元在逻辑段内相对于该段第一个存储单元的距离。 20位物理地址 = 段地址16 + 偏移地址取指令操作CS 16 + IP堆栈操作SS 16 + SP 数据存储器操作DS/ES 16 + 偏移地址问题3:请说明段寄存器与提供偏移地址寄存器的对应关系。答:CS:IP对应代码段,DS:SI(或DI或BX)对应数据段,SS:SP(或BP)对应堆栈段。问题4:8086的有最大和最小两种工作模式,请说明两种工作模式下的特点,并说明如何进行工作模式的设置。答:8086微处理器有最小模式和最大模式。最小模式为单处理器模式,最大模式为多处理器模式;最小工作方式下总线控制信号都直接由8086产生,系统中总线控制逻辑电路被减小到最小,这种方式适合于较小规模系统的应用。最大工作方式用在需要利用8086CPU构成中等或较大系统时。由MN/MX的电平高低进行工作模式的设置。(+5V最小、接地最大)问题5:从功能上看,CPU可以分为哪两部分?各负责什么工作?有什么优点?答:从功能上看8086CPU可分为两部分:1)总线接口部件BIU 负责指令和操作数读及结果写。2)执行部件EU负责指令的执行。两个部件独立地进行操作,即并行工作,使得取指令、分析指令和执行指令可以并行操作,提高了CPU的工作效率,加快了指令的执行速度。问题6:微型计算机由哪几部分组成?简述各部分功能。答:微型计算机系统主要由微处理器(CPU)、存储器、I/O接口和总线组成。其中微处理器为微型计算机的核心,主要完成取指令、指令译码、简单的算术逻辑运算及程序控制等;存储器主要用来存储程序和数据;I/O接口用于外设与CPU之间的信息协调;总线是CPU与存储器和I/O接口之间传送数据信息、地址信息和控制信息的通道。问题7:什么是指令?什么是指令系统?请说明指令系统在微机系统中重要性。答:指令就是计算机执行某种操作的命令,指令系统是该计算机所以指令的集合,它是综合反映计算机性能的重要因素,不仅直接影响机器的硬件结构,而且影响机器的系统软件及机器的适用范围。问题8:什么是数据的寻址方式?8086/8088的微机系统中有哪些数据寻址方式?答:所谓数据的寻址方式就是寻找指令中所需操作数的方法。寻址方式有:隐含寻址,立即数寻址,寄存器寻址,直接寻址,寄存器间接寻址,寄存器相对寻址,基址变址寻址,相对基址变址寻址。问题9:什么是中断类型码、中断向量、中断向量表?在基于8086/8088的微机系统中,中断类型码和中断向量之间有什么关系?答:处理机可处理的每种中断的编号为中断类型码。中断向量是指中断处理程序的入口地址,由处理机自动寻址。中断向量表是存放所有类型中断处理程序入口地址的一个默认的内存区域。在8086系统中,中断类型码乘4得到向量表的入口,从此处读出4字节内容即为中断向量。问题10:什么叫中断?请叙述中断向量号(中断类型)、中断向量表和中断服务程序入口地址三者的关系。 答:中断由请求中断的外部设备口向CPU提供中断向量,CPU根据这个向量到向量表中转换表跳转中查找中断服务程序入口地址,而转入不同的中断处理服务程序入口。8088/8086可以处理256种向量中断,对每种中断都指定一个中断向量号代码,从0255每一种中断向量号代码都可以与一个中断服务程序相对应。中断服务程序放在存储区域内,而中断服务程序的入口地址存在内存储器中断向量表内,当CPU处理中断时,就需要指向中断服务程序入口地址,中断向量表是中断向量号与这相应的中断服务程序入口地址之间的转换表。中断向量表占用存储器的最低地址区,因为每个中断向量号要占用4个字节单元。问题8:8259A中断控制器的功能是什么?答:8259A中断控制器可以接受8个中断请求输入并将它们寄存。对8个请求输入进行优先级判断,裁决出最高优先级进行处理,它可以支持多种优先级处理方式。8259A可以对中断请求输入进行屏蔽,阻止对其进行处理。8259A支持多种中断结束方式。8259A与微处理器连接方便,可提供中断请求信号及发送中断类型码。8259A可以进行级连以便形成多于8级输入的中断控制系统。二、指令改错错误1:存储器操作数之间不能直接传送 MOV 1000H,DI 错 应改为 MOV AX,DI MOV 1000H,AX 错误2:立即数不能直接传送段寄存器 MOV DS,2000H 错 应改为 MOV AX,2000H错误3:段寄存器之间不能直接传送 MOV ES,DS 错 应改为 MOV BX , DS MOV ES , BX错误4:CS、 IP、PSW只可以作为源操作数即不允许给CS、IP、PSW三个寄存器传送数据 MOV CS,AX 错 MOV AX,CS 对错误5:源操作数和目的操作数的宽度必须相同 MOV AL,050AH 错 MOV AX,050AH 对错误6:POP、PUSH指令不以字为操作数 POP DL 错错误7:端口地址8位,超出范围IN AX ,1234H三、分析程序例题1 设初值为AX=1234H,BX=5678H,DX=0ABCDH,则下面一段程序: MOV CL,4 SHL DX,CL MOV BL,AH SHL AX,CL SHR BL,CL OR DL,BL执行后,请问AX=?,BX=?,DX=?AX=2340H BX=5601H DX=BCD1H 例题2 MOV AX,10SAL AL,1MOV BX,AXMOV CL,2SAL AL,CLADD AX,BX 执行后,AX为?AX=100例题3 设初值(AX)4321H,(DX)8765H,则MOV CL,04HSHL DX,CLMOVBL,AHSHLAX,CLSHRBL,CLORDL,BL上述程序执行后(DX) ;(AX) (DX)7654H,(AX)3210H例题4 假如在程序的括号中分别填入指令:(1) LOOP L20(2) LOOPNE L20(3) LOOPE L20试说明在三种情况下, 当程序执行完后, AX、BX、CX、DX四个寄存器的内容分别是什么? CODESGSEGMENTASSUMECS:CODESG, DS:CODESG. SS:CODESGORG100HBEGIN:MOVAX,01MOVBX,02MOVDX,03MOVCX,04L20:INC AXADDBX,AXSHRDX,1( )RETCODESGENDSENDBEGIN答: (1)(AX)= 5 (BX)= 16 (CX)= 0 (DX)= 02)(AX)= 2 (BX)= 4 (CX)= 3 (DX)= 1(3)(AX)= 3 (BX)= 7 (CX)= 2 (DX)= 0例题5 以下程序实现的功能是什么20H*30H?结果存放在哪里?AXSTART: MOV AL, 20H MOV BL,AL MOV AL, 30H MOV CL, AL MOV AX, 0NEXT: ADD AL, BL ADC AH, 0 DEC CL JNZ NEXT HLT例题6:若从NUM开始的存储区存放着ASCII码表示的字符串,指出下列程序的功能。LEA BX,NUMMOV CX,100 LP:MOV AL,BXSUB AL,30HCMP AL,0AHJC L1SUB AL,07H L1:MOV BX,ALINC BXLOOP LPHLT四、编程题例题1 两个32位加数98765432H和8901FA45H分别存放在数据段内2000H单元和2004H单元,编程将两数相加,结果从2100H单元开始存放。MOV AX,2000H ;AX=5432H,被加数低16位 MOV BX,2002H ;BX=9876H,被加数高16位 ADD AX,2004H ;低16位相加,AX=4E77H ADC BX,2006H ;高16位及低16位的进位相加,BX=2178H MOV 2100H,AX ;存低16位的和4E77H MOV 2102H,BX ;存高16位的和2178H MOV AX,0 ADC AX,0 ;获得最高位的进位 MOV 2104H,AX ;存和的最高位例题2 计算(V-(X*Y+Z)/X, XYZV均为16位有符号数,要求商存入AX,余数存入DX MOV AX, X ;X*Y IMUL Y MOV CX,AX MOV BX,DX ;积存入BX,CX MOV AX,Z CWD ;Z扩展 ADD CX,AX ADC BX,DX ;X*Y+Z MOV AX,V CWD ;V扩展 SUB AX,CX SBB DX,BX ;相减 IDIV X ;除以X 例题3 用XLAT指令将BCD码09转换成对应的ASCII码,并将ASCII码存入ARRAY中。例题4 设在内存缓冲区中有一数据块BUF,存放着100名学生某门课程的考试成绩(满分为100分,最低为0分),求出成绩不低于90分以及成绩低于60分的学生个数,并将它们分别存于符号地址为GOOD和FAIL的2个内存单元中。要求画出程序流程框图,编写完整的汇编语言源程序。DATA SEGMENTBUF DB 100 DUP (?)GOOD DB 0FAIL DB 0DATA ENDSCODE SEGMENTASSUME CS:CODE, DS:DATASTART:MOV AX, DATAMOV DS, AXMOV BX, OFFSET BUFMOV CX,100MOV DX,0L1:MOV AL, BXCMP AL,90JB L2INC DHJMP L3L2:CMP AL,60JAE L3INC DLL3:INC BXLOOP L1MOV GOOD, DHMOV FAIL, DLMOV AH, 4CHINT 21HCODE ENDSEND START五、存储器例题1 图示为某CPU的最小系统和某存储芯片的框图,已知该CPU共有8位数据总线,最大可以访问1MB的存储空间,其内部结构与8086相同,请回答以下问题:1、将图中CPU的相关信号线与存储器相连。2、 要求1#存储器的起始地址为32000H,2#存储器的起始地址为38000H,且各存储单元的地址唯一。根据需要选择合适的门电路与138译码器一起完成译码,画出译码电路图。3、编写程序片段把1#存储器内容的绝对值按顺序存储到2#存储器。最小系统(1)正确连接CPU相关信号最小系统(2)1.、地址译码输入连接,译码电路不唯一2.、存储器片选连接&3)程序片段(参考程序,不唯一)MOV AX,3000HMOV DS,AX MOV SI,2000H MOV DI,8000H MOV CX,2000H L1:MOV AL,SICMP AL,0JGE L2 NEG ALL2: MOV DI,AL INC SIINC DI LOOP L1 例题2六、综合应用题例题1. 已知某8088微机系统包括8255、8253两个可编程接口电路。其中8253三个计数器分别工作在不同的方式下,可以为AD转换器提供可编程的采样频率和采样时间;8255A的PB0可用于检测按键开关的位置,PB7可根据PB0的状态决定是否点亮LED指示灯。设系统所要求有关硬件连线已经全部接好,如图所示。试完成下列各项要求。(1) 分别列出8255A,8253各个端口的地址编码,其中片选信号,采用图2中的译码地址。(2) 根据图2所示8255A的A口和B口的连接方式,写出接口初始化程序片段。(3) 设计一个程序片段,使8255A监测PB0的输入状态,当PB01时使LED灯亮。(1) 8255的口地址码为08H,09H,0AH,0BH,8253的口地址码为0CH,0DH,0EH,0FH(2) 8255的初始化程序MOV AL,10000010BOUT 0BH,AL(3) 8255检测到当PB01时点亮灯的程序片段IN AL,09H;读B口状态K1: TEST 01H;测试PB01否 JZ K1 ;不为1,踏步 MOV AL,00H;PB01,使PA00,点亮LED OUT 08H,AL例题2 图示为键盘电路,试编写8255初始化程序和键值读取程序,并将键值序号在LED七段数码管显示出来。DATA SEGMENT;数据段中存放数字0 9的LED显示代码LED DB 3FH,06H

温馨提示

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

评论

0/150

提交评论