《微机原理及应用》期末自测题一、基本概念与术语1、现代计算机中表达信息采用数进行编码,8086就是位计算机。
2、8086地址线有条,可直接寻址的空间最大为。
3、总线周期就是指;基本总线周期有T状态;Tw状态就是指。
4、8086CPU允许的I/O地址线最多可达条,最大寻址I/O空间为。
5、8086CPU由两部分组成,其功能为。
其中8086C PU中标志寄存器的作用就是,指令队列的作用就是,20位地址加法器的作用就是。
6、代码段物理地址由CPU的两个寄存器确定。
堆栈段物理地址由CPU的两个寄存器确定。
7、8086CPU预取指令存放于;段寄存器CS与的内容始终指向顺序存储的下一字节指令。
8、8086中断源有个。
8086中断服务程序入口地址由组成。
中断类型号为20H,其中断向量为。
9、8086CPU中断源包含硬件中断与软件中断, 属于软件中断。
10、I/O指令IN/OUT,传送数据的寄存器为,间接寻址时使用寄存器,其中IN AL,DX的含义就是。
OUT 60H,AL的含义就是。
11、一片8259A可以管理级中断;3片8259A可以管理级中断。
12、硬件中断就是(外部引发?随机的?执行总线周期?中断类型码由?提供),软件中断就是(内部引发?确定的?不执行总线周期?中断类型确定?)软件中断优先级与硬件中断优先级相比, 的级别高。
13、在中断服务程序结束前,为正确返回,必须设置一条指令。
在子程序调用结束前,为正确返回,必须设置一条指令。
14、若中断控制器8259的中断请求寄存器IRR状态为10100000B,说明。
ISR状态为10100000B说明。
15、可编程定时器8253的地址有个。
共有独立定时通道。
工作方式有个。
16、并行接口8255有个数据端口,有种工作方式。
17、假设8253的端口地址为40H~43H,那么控制端口地址为,通道0、1、2的端口地址为。
18、假设8255的端口地址为330H~333H,控制端口地址为,端口A、B、C的地址为。
19、定时器8253的门控信号GA TE作用就是,CLK端的作用就是,OUT端作用就是。
20、初始化定时器8253需要先写,后写。
21、伪指令的作用就是,产生机器代码。
22、输入输出指令中,数据寄存器由( )寄存器指出。
A) AL/AXﻩﻩB) BXﻩﻩﻩC) CXﻩﻩﻩﻩD) DX23、以下关于可编程计数/定时器8253说法错误的就是( )。
A)、有3个独立的16位计数/定时器B)、每个计数/定时器都有6中工作方式C).每个定时/计数器都有时钟输入CLK、定时输出OUT与门控信号GATAD)、每个定时/计数器都用二进制计数,不能用BCD码计数24、汇编语言程序中用于指定段与段寄存器之间关系的伪指令就是( A (P95))。
A) ASSUME ﻩB) EQUﻩﻩﻩC)SEGMENT D) ORG25、下列指令中,能够实现当操作结果为零,转向标号GOON功能的就是( )。
A) JBﻩGOONB) JA GOONﻩC)JLﻩGOON ﻩﻩD) JZﻩGOON26、在8255三种工作方式中,方式1与方式2需要提供“握手”信号,该信号由( )端口提供。
A) PA端口ﻩﻩB) PB端口C) PC端口ﻩﻩﻩD) PA、PB端口二、简单应用与简答题1、简述微型计算机的组成。
2、总线分为哪几种类型?微型计算机采用总线结构有什么优点?3、8086 CPU在内部结构上由哪几部分组成?其功能就是什么?4、8086的总线接口部件由那几部分组成? 其作用就是什么?5、8086的执行单元(部件)由那几部分组成?有什么功能?6、8086内部有哪几个通用寄存器?作用就是什么?7、8086内部有哪几个段寄存器?作用就是什么?8、简述8086CPU的流水线思想,与传统计算机有何不同。
9、8086与8088就是怎样解决地址线与数据线的复用问题的? ALE信号何时处于有效电平?10、8086工作在最小模式与最大模式的区别及主要特点就是什么?11、存储器的逻辑地址由哪两部分组成?物理地址就是如何形成的?8086的地址线有多少条?最大物理地址空间为多少?12、根据不同的寻址方式,说明操作数所处位置有哪些?13、汇编语言中指令与伪指令有什么区别?14、什么就是端口?通常有哪几种端口?它们的作用就是什么?15、计算机对I/O端口编址时通常采用哪两种方法?在8086/8088系统中,用哪种方法对I/O 端口进行编址?16、一般的IO接口电路安排有哪三类寄存器?它们各自的作用就是什么?17、简述CPU与外设进行数据交换的几种常用方式与特点。
18、简述条件传送方式的工作过程,主要适用的场合。
19、什么就是中断优先权?什么就是中断嵌套?什么就是可屏蔽中断?20、软件中断有哪些特点?硬件中断有那些特点?21、在中断处理子程序与主程序的关系上,软件中断与硬件中断有什么不同之处?22、8086 CPU响应中断的流程包含哪四个阶段?23、简述中断控制器8259的主要功能。
24、8086CPU响应中断的条件?8086 CPU响应中断后自动完成的任务就是什么?25、什么就是中断向量?它放在哪里?对应于类型号1CH的中断向量在哪里?如1CH中断程序从5110H :2030H开始,则中断向量应怎样存放?26、简述定时器/计数器芯片8253的主要功能。
说明OUT、CLOCK与GATE信号的作用。
27、定时器8253内部有几个独立通道?8253有几种工作方式?28、定时器8253内部计数器就是16位,数据线为8条,如何写入16位计数初值?29、初始化定时器8253的步骤就是什么?若8253端口地址为200H-203H,对应的端口就是哪个? 30、并行接口8255有几个数据端口?若端口地址为300H-303H,对应的端口就是哪个?端口C除了可做数据口外,还有什么功能?31、假设8255A的端口A工作于方式0,外设需要提供两个联络信号,一个为输出选通,一个为外设就绪信号输入,试选择端口并说明理由。
32、8255的3个端口24条外设数据线有什么特点?三、编程应用题1、编程计算((X+Y)*10)+Z)/X,X、Y、Z都就是16位无符号数,结果存在RESULT开始的单元。
2、将BUF1开始的100字节传送到BUF2开始的单元,然后从中检索字符“#”,并将此单元换成空格字符。
3、编写一段程序,比较两个5字节的字符串OLDS与NEWS,若相同,在RESULT置0,否则置0FF H。
4、累加数组中的元素,将与存于SUM开始单元,再求平均值,平均值存于AVR单元。
数据段定义如下DA TAﻩSEGMENTARRAY DW 10,10,12,4,5,6,7,8,9,10COUNT DW ($-ARRAY)/2SUMDW 0,0ﻩﻩAVRDW 0DATAﻩENDS5、统计数组中大于100的数据的数量,存于N1单元,数据段定义如下TAB1 DB100,200,12,40,50,60,70,80,90,105N EQU$-TABN1DB 06、编写程序完成求1+2+3+……N的累加与,直到累加与超过1000为止。
统计被累加的自然数的个数送CN单元,累加与送SUM。
7、设有两个长度为8个字节的无符号数分别存放在以NUM1、NUM2为首地址的连续的内存单元中,将两个数相加,结果存入SUM内存单元中。
(例4.6)8、统计数据块中正数与负数的个数,并将正数与负数分别送到两个缓冲区(习题4、12)。
数据变量定义如下:BLOCK DB -1,-3,5,6,-2,0,20,10N EQU$-BLOCKPLUS_D DB 8DUP(?) ;正数缓冲区PLUSDB 0 ;正数个数MINUS_D DB 8 DUP(?) ;负数缓冲区MINUS DB 0 ;负数个数9、从给定串中寻找最大值,并放到MAX单元,元素放在BUFFER开始的字节单元中。
10、把BUF表中的字节元素按值的大小升序排列。
数据段定义如下:BUF DB 10,32,56,11,90,56,89,21N = $-BUF11、类型号为20H的中断服务程序入口符号地址为INT-5,试写出中断向量的装入程序片断。
12、设一个8253的计数器0产生周期为20ms的定时信号,计数器1产生周期为300us的定时信号。
设外部时钟频率为f=2MHZ,端口地址为330H~333H。
试对它进行初始化编程。
13、已知某8253占用I/O空间地址为340H~343H,设定时器0、定时器1工作于方式3,外部提供一个时钟,频率f=2MHZ。
要求定时器1连续产生5ms的定时信号,定时器0连续产生5秒的定时信号。
14、用8255A控制三个发光二极管依秩序循环显示。
假设开关闭合时,点亮发光二极管,开关断开时熄灭二极管。
(1)画出原理图,并说明工作原理;(2)选择8255工作方式;(3)编写8255初始化程序与控制程序。
15、8255连接一组开关与一组LED显示器,如图所示。
开关状态控制LED显示,若断开,则全部熄灭。
8255端口地址为310H~313H,8255工作于方式0。
要求:(1)若K0闭合,发光二极管全部亮;(2)开关K1闭合,全部发光二极管同时闪烁(延时2秒);(3)开关K2闭合,发光二极管依次循环点亮(依次延时1秒);假设已有延时1s的子程序DELAY,编写完整8255初始化程序与控制程序。
以下就是部分功能的程序片段提示:COTREQU 313H ;8255A控制口地址8255A的A口地址;PORT_A EQU310HﻩPORT_C EQU 312H……;------------8255初始化-------------Wait: MOVDX,COTRMOV AL,10010000B ;8255方式0,PA口输入,PC口输出OUT DX, AL;-------------LED依次点亮----------------ONElightONE PROC ;依次点亮MOVﻩDX,PORT_C;端口C地址ﻩﻩMOVﻩAL, 00000001B ;PC0输出高电平ﻩOUT DX, AL;L0发光CALLﻩDELAY ;延时ﻩ、.、..、;点亮L1发光,延时.、、.、.;点亮L2发光,延时、、、、.、;点亮L3发光,延时ﻩRETONElightONEENDP四、读程序写出结果。
1、8086 CPU执行如下指令后的结果,以及标志CF、ZF的值。
MOV ﻩAL, 80HSUB AL, 10H ;(AL)=?ADD AL, 89H ;(AL)=?,CF=?,ZF=?2、CPU执行如下指令后的结果。
MOVAX,1234HMOV BX,5678HPUSH AXPOP CXAX=?, BX=?,CX=?3、ﻩORG 1000HTABLEDB0,1,2,3NﻩEQU$-TABLEZER DW 8DUP(1)写出执行下列指令结果.ﻩMOV AL, TABLEMOVBX, OFFSET TABLEﻩﻩMOV CX, NMOV DX,LENGTH ZERﻩMOV SI,WORD PTR TABLE+14、读程序,写出结果。