完整word版计算机考研必备微型计算机原理及应用试题精选.docx
《完整word版计算机考研必备微型计算机原理及应用试题精选.docx》由会员分享,可在线阅读,更多相关《完整word版计算机考研必备微型计算机原理及应用试题精选.docx(32页珍藏版)》请在冰点文库上搜索。
完整word版计算机考研必备微型计算机原理及应用试题精选
微机原理试题1
一、填空(每空1分,共10分)
1.01011101.101B=D=H=()BCD。
2.一个有16个字的数据区,它的起始地址为70A0:
DDF6,那么该数据区的最后一个字的物理首地址为。
3.在IBM-PC/XT中,外设是通过器件对CPU产生中断请求。
这些中断的中断类型码为。
4.8088在访问4个当前段时,代码段、数据段及堆栈段的偏移量分别由、和提供。
5.在8088读存储器周期中,采样Ready线的目的是。
二、(8分)下列程序段的功能是完成S=(a*b+c)/a的运算,其中变量a,b,c,和s均为带符号的字数据,结果的商存入s,余数则不计,请在下列空格中填入合适的指令(注:
请按注释填空)。
MOVAX,a
A*b在CX:
BX中
MOVAX,C
C在DX:
AX中
a*b+c在DX:
AX中
商存入S
三.简答题
1.(6分)在8088CPU的最大方式系统中,设20位地址全部需要锁存,数据线使用总线收发器,请问该CPU与系统总线的接口逻辑中需要哪些芯片?
各需多少片?
并叙述每块芯片的作用。
2.(6分)PC/XT机的输入输出方式有哪几种?
各有什么特点?
四、(10分)下图是一个存储器系统,地址总线共有20位,数据总线8位,试分析电路,回答1、2、3、4题问题。
1.单片EPROM和单片SRAM的容量各为多少?
2.74LS138的作用是什么?
3.EPROM2的地址范围是多少?
4.SRAM2的地址范围是多少?
五、(10分)设在最大方式下,8086系统中有一块主8259A和一块从8259A,从8259A接至主8259A的IR1上,主、从8259A的偶地址分别是0200H和0210H。
主8259A的IR0中断类型码是30H,从8259A的IR0的中断类型码是38H。
所有请求都是边沿触发,用EOI命令清ISR位,两块8259A采用级联方式连接。
主、从8259A的IMR都清除,
用作输入。
试编写该中断系统的初始化程序。
六、(10分)设外部有一脉冲信号源PLUS,要求用8253—5的计数器0对该信号源连续计数,当计数器计为0时向CPU发出中断请求。
要求:
1.画出8253-5的CLK0、GATE0和OUT0的信号连接图。
2.若该芯片的端口地址为40H~43H,计数初值为1234H,写出该计数器工作在方式2按二进制计数的初始化程序。
3.若计数初值为12345H,在上述基础上增加计数器1如何连接以实现计数。
七、(10分)假设8255A芯片起始端口地址为60H,编写指令序列,分别完成:
1.设置端口A组和B组都是方式0,其中端口B和C是输出口,A为输入口。
2.设置端口A组为方式2、B组为方式0且端口B为输出。
3.设置端口A组为方式1且端口A为输入、PC6和PC7为输出;设置端口B组为方式1且端口B为输入。
八、(15分)在8086系统下,编写完整程序,找出字节数组ARRAY中的最大值和最小值。
假设ARRAY的长度为100个字节,每个字节为一个无符号数,程序执行后最大值将存放到字节变量MAX中,最小值则存放到字节变量MIN中。
九、(15分)阅读下列程序,说明程序的功能,画出流程图。
DATASEGMENT
XDWX1,X2,X3,X4,X5,X6,X7,X8,X9,X10
YDWY1,Y2,Y3,Y4,Y5,Y6,Y7,Y8,Y9,Y10
ZDWZ1,Z2,Z3,Z4,Z5,Z6,Z7,Z8,Z9,Z10
LOGIC_RULEDW00DCH
DATAENDS
STACKSEGMENTPARASTACK'STACK'
DB100DUP(?
)
STACKENDS
CODESEGMENT
ASSUMECS:
CODE,DS:
DATA,SS:
STACK
STARTPROCFAR
BEGIN:
PUSHDS
MOVAX,0
PUSHAX
MOVAX,DATA
MOVDS,AX
MOVBX,0
MOVCX,10
MOVDX,LOGIC_RULE
NEXT:
MOVAX,X[BX]
SHRDX,1
JCSUBTRACT
ADDAX,Y[BX]
JMPSHORTRESULT
SUBTRACT:
SUBAX,Y[BX]
RESULT:
MOVZ[BX],AX
LOOPNEXT
RET
STARTENDP
CODEENDS
ENDBEGIN
微机原理与应用试题2
一、填空(每空1分,共8分)
1.标志寄存器中的6个状态位分别是。
2.8086/8088CPU内存最大寻址范围为字节。
3.设某存储芯片内有1024个单元,若用单译码方式,地址译码器将有条输出线;若使用双译码器方式,用两个相同的译码器,共需要条译码输出线。
4.某芯片采用的是地址复用技术,共有七条地址引脚。
若它的首地址是0000H,则其末地址为。
5.MOS型半导体随机存储器可分为和两种,后者在使用过程中每2mS内要刷新一次。
6.软中断指令INT20H的中断服务程序的入口地址在地址为:
的四个内存单元中。
二、(10分)改正下列有错误的指令
1.IN200H,AL5.DIVAX,59.MOVBYTEPTR[BX],256
2.MOVES,6000H6.SALAL,210.PPDB56,78,……
3.LOOPADD7.MOVDX,2000HMOVAX,PP
4.LEADI,[AX]8.PUSHCH11.CMP[DX],80H
三.简答题
(1)(5分)试说明8086/8088工作在最小方式下和最大方式下系统基本配置的差别。
在最大组态下,8086/8088的外围电路由哪些器件组成?
它们的作用是什么?
(2)(7分)什么是DMA?
DMA操作可以分几个主要步骤?
四、(10分)某微机系统的CPU为8088,且工作于最小方式,原有系统RAM存储器模块的容量为128K字节,其首地址为40000H,现用2128RAM芯片(容量2K×8位)扩展一个容量为16K字节的存储器模块,地址和原有RAM模块的地址相连接,试完成该扩展RAM模块的设计。
(注:
可选用3:
8译码器、与门、或门、非门等)。
五.(10分)8253-5通道1工作于方式3,输入时钟频率为1MHz,OUT引脚输出周期为20ms的方波。
已知通道0的口地址为4F0H,试编写初始化程序段。
8253-5的控制字格式为:
六.(10分)
(一)试述中断的一般过程。
(二)写出只有一块8259A的8088系统中8259A的初始化程序,8259A的偶地址为2150H,要求:
(a)请求电平触发;
(b)IR0请求的中断类型是28H;
(c)
SP/EN输出一个信号,给数据总线收发器;
(d)在第二个INTA脉冲结束时,ISR位自动清除;
(e)清IMR。
已知8259A初始化命令字格式如下:
A0D7D0
ICW1
0
×
×
×
1
LTIM
×
SNGL
IC4
A0D7D0
ICW2
1
T7
T6
T5
T4
T3
主ICW3
A0D7D0
1
S7
S6
S5
S4
S3
S2
S1
S0
从ICW3
A0D7D0
1
0
0
0
0
0
ID2
ID1
ID0
ICW4
A0D7D0
1
0
0
0
SFNM
BUF
M/S
AEOI
μPM
七、(10分)关于8255A
(一)简述8255A芯片
、
、
和RESET的功能
(二)假设某8255A芯片起始端口地址为800H,请编写程序段完成下列功能:
(1)设置端口A组和B组都是方式0,其中端口A输出,端口B输入,C口上半部分输入。
(2)查询PC7位,若PC7=0继续查询;若PC7=1,则从A口输入字符送B口输出。
并无限循环重复上述过程。
已知8255A方式选择控制字格式为:
8255方式字格式为:
D7
D6D5
D4
D3
D2
D1
D0
1
A组方式
端口AI/O
C上I/O
B组方式
端口BI/O
C下I/O
八(15分)、阅读下列程序,说明程序的功能,画出程序的流程图。
DATASEGMENT
NUMDW1234H,5678H,9ABCH,0DEF0H
LTH_WDW($-NUM)/2
AFTERDB‘H’,0DH,0AH,‘$’
DATAENDS
STACKSEGMENTPARASTACK'STACK'
DB100DUP(?
)
STACKENDS
CODESEGMENT
ASSUMECS:
CODE,DS:
DATA,SS:
STACK
MAINPROCFAR
PUSHDS
MOVAX,0
PUSHAX
MOVAX,DATA
MOVDS,AX
MOVCX,LTH_W
LEASI,NUM
L:
CALLSHOW_W
INCSI
INCSI
LOOPL
RET
MAINENDP
SHOW_WPROC
PUSHCX
MOVDL,[SI+1]
MOVCL,4
SHRDL,CL
CALLSHOW_1
MOVDL,[SI+1]
ANDDL,0FH
CALLSHOW_1
MOVDL,[SI]
MOVCL,4
SHRDL,CL
CALLSHOW_1
MOVDL,[SI]
ANDDL,0FH
CALLSHOW_1
LEADX,AFTER
MOVAH,09H
INT21H
POPCX
RET
SHOW_WENDP
SHOW_1PROC
CMPDL,9
JBENEXT
ADDDL,7
NEXT:
ADDDL,30H
MOVAH,02H
INT21H
RET
SHOW_1ENDP
CODEENDS
ENDMAIN
九、(15分)编写完整的源程序。
存储器变量STRING中存放一字符串,字符串长度放在字变量STR_LEN中,编程查找串中第一个出现关键字符‘A’的位置。
如果找到,则把该位置相对于串首的偏移量存放到存储单元RES中,否则将RES的值置为0FFFFH。
例如,在串“ABAB”中查找字符“A”,由于串中第一个“A”出现在串首,所以结果RES=0。
请编写完整的源程序实现上述功能。
微机原理试题1答案
一、填空
1.01011101.101B=93.625D=5D.AH=(10010011.011000100101)BCD
2.一个有16个字的数据区,它的起始地址为70A0:
DDF6,那么该数据区的最后一个字的物理首地址为7E814H。
3.在IBM-PC/XT中,外设是通过8259器件对CPU产生中断请求。
这些中断的中断类型码为08H—0FH。
4.8088在访问4个当前段时,代码段、数据段及堆栈段的偏移量分别由IP、由寻址方式决定的16位偏移量和SP提供。
5.在8088读存储器周期中,采样Ready线的目的是确定是否在T3周期后插入Tw周期。
二、(8)、下列程序段的功能是完成S=(a*b+c)/a的运算,其中变量a,b,c,和s均为带符号的字数据,结果的商存入s,余数则不计,请在下列空格中填入合适的指令(注:
请按注释填空)。
MOVAX,a
IMULb
A*b在CX:
BX中
MOVCX,DX
MOVBX,AX
MOVAX,C
C在DX:
AX中
CWD
ADDAX,BX
a*b+c在DX:
AX中
ADCDX,CX
IDIVa
商存入S
MOVS,AX
三、简答题
1.在8088CPU的最大方式系统中,设20位地址全部需要锁存,数据线使用总线收发器,请问该CPU与系统总线的接口逻辑中需要哪些芯片?
各需多少片?
并叙述每块芯片的作用。
答:
8284一片:
给CPU提供RESET、READY、CLK信号;
8282三片:
锁存20位地址;
8286一片:
增强总线带负载能力,(或数据驱动);
8288一片:
从CPU接收S2S1S0信号,发出相应的控制信号。
2.PC/XT机的输入输出方式有哪几种?
各有什么特点?
答:
(1)无条件:
需要外设处于就绪状态,硬件简单;
(2)查询:
CPU需要不断地查询外设是否就绪,浪费CPU时间,硬件较简单;
(3)中断:
外设准备好后,向CPU发中断请求,请求CPU完成数据传输,外设与CPU并行;硬件又比前两者复杂。
(4)DMA:
CPU对DMAC初始化后,由DMAC控制总线完成数据传送;CPU与I/O并行。
速度快,用于大量数据传输。
DMAC占用总线时,CPU不能用。
硬件更复杂。
四、下图是一个存储器系统,地址总线共有20位,数据总线8位,试分析电路,回答1、2、3、4题问题。
1.单片EPROM和单片SRAM的容量各为多少?
2.74LS138的作用是什么?
3.EPROM2的地址范围是多少?
4.SRAM2的地址范围是多少?
答:
1.EPROM单片容量为4K×8位,SRAM单片容量为2K×8位。
2.74LS138的作用是译码。
3.ERROM2的地址范围为:
F9000H~F9FFFH。
4.SRAM2的地址范围为:
FC800H~FCFFFH。
五、设在最大方式下,8086系统中有一块主8259A和一块从8259A,从8259A接至主8259A的IR1上,主、从8259A的偶地址分别是0200H和0210H。
主8259A的IR0中断类型码是30H,从8259A的IR0的中断类型码是38H。
所有请求都是边沿触发,用EOI命令清ISR位,两块8259A采用级联方式连接。
主、从8259A的IMR都清除,
用作输入。
试编写该中断系统的初始化程序。
答:
对于8086CPU,若主8259A的偶地址为0200H,则奇地址为0202H;若从8259A的偶地址为0210H,则奇地址为0212H。
;主8259A初始化程序:
INTA0EQU0200H;
INTA1EQU0202H
MOVAL,11H;00010001B
MOVDX,INTA0
OUTDX,AL;ICW1
MOVAL,30H
MOVDX,INTA1
OUTDX,AL;ICW2
MOVAL,02H;00000010B
OUTDX,AL;ICW3
MOVAL,11H;00010001B
OUTDX,AL;ICW4
;从8259A初始化程序:
INTA0EQU0210H
INTA1EQU0212H
MOVAL,11H
MOVDX,INTA0
OUTDX,AL;ICW1
MOVAL,38H
MOVDX,INTA1
OUTDX,AL;ICW2
MOVAL,01H
OUTDX,AL;ICW3
MOVAL,01H;00000001B
OUTDX,AL;ICW4
六、设外部有一脉冲信号源PLUS,要求用8253—5的计数器0对该信号源连续计数,当计数器计为0时向CPU发出中断请求。
要求:
1.画出8253-5的CLK0、GATE0和OUT0的信号连接图。
2.若该芯片的端口地址为40H~43H,计数初值为1234H,写出该计数器工作在方式2按二进制计数的初始化程序。
3.若计数初值为12345H,在上述基础上增加计数器1如何连接以实现计数。
答:
1.
2.MOVAL,34H
OUT43H,AL
MOVAL,34H
OUT40H,AL
MOVAL,12H
OUT40H,AL
3.PLUS作CLK0的输入,OUT0的输出作CLK1的输入信号。
OUT1的输出作CPU的请求信号。
用两个计数器串联计数实现20位二进制的计数
七、假设8255A芯片起始端口地址为60H,编写指令序列,分别完成:
1.设置端口A组和B组都是方式0,其中端口B和C是输出口,A为输入口。
2.设置端口A组为方式2、B组为方式0且端口B为输出。
3.设置端口A组为方式1且端口A为输入、PC6和PC7为输出;设置端口B组为方式1且端口B为输入。
答:
1.MOVDX,0063H
MOVAX,0090H
OUTDX,AX
2.MOVDX,0063H
MOVAX,00D0H
OUTDX,AX
3.MOVDX,0063H
MOVAX,00B2H
OUTDX,AX
八、在8086系统下,编写完整程序,找出字节数组ARRAY中的最大值和最小值。
假设ARRAY的长度为100个字节,每个字节为一个无符号数,程序执行后最大值将存放到字节变量MAX中,最小值则存放到字节变量MIN中。
参考程序:
DATASEGMENT
ARRAYDB100DUP(?
);字节数组
MAXDB?
;最大值
MINDB?
;最小值
DATAENDS
CODESEGMENT
ASSUMECS:
CODE,DS:
DATA
MAINPROCFAR
PUSHDS
MOVAX,0
PUSHAX
MOVAX,DATA
MOVDS,AX
LEASI,ARRAY
CLD
MOVBH,0;存放临时最大值的寄存器
MOVBL,0FFH;存放临时最小值的寄存器
MOVCX,100
AGAIN:
LODSB
CMPAL,BH
JNANEXT1
MOVBH,AL;如果当前数值比临时最大值大,则代替
NEXT1:
CMPAL,BL
JNBNEXT2
MOVBL,AL;如果当前数值比临时最小值小,则代替
NEXT2:
LOOPAGAIN
MOVMAX,BH
MOVMIN,BL
RET
MAINENDP
CODEENDS
ENDMAIN
九、(15分)阅读下列程序,说明程序的功能,画出流程图。
DATASEGMENT
XDWX1,X2,X3,X4,X5,X6,X7,X8,X9,X10
YDWY1,Y2,Y3,Y4,Y5,Y6,Y7,Y8,Y9,Y10
ZDWZ1,Z2,Z3,Z4,Z5,Z6,Z7,Z8,Z9,Z10
LOGIC_RULEDW00DCH
DATAENDS
STACKSEGMENTPARASTACK'STACK'
DB100DUP(?
)
STACKENDS
CODESEGMENT
ASSUMECS:
CODE,DS:
DATA,SS:
STACK
STARTPROCFAR
BEGIN:
PUSHDS
MOVAX,0
PUSHAX
MOVAX,DATA
MOVDS,AX
MOVBX,0
MOVCX,10
MOVDX,LOGIC_RULE
NEXT:
MOVAX,X[BX]
SHRDX,1
JCSUBTRACT
ADDAX,Y[BX]
JMPSHORTRESULT
SUBTRACT:
SUBAX,Y[BX]
RESULT:
MOVZ[BX],AX
INCBX
LOOPNEXT
RET
STARTENDP
CODEENDS
ENDBEGIN
答:
设有数组X和Y。
X数组中有X1,…,X10;Y数组中有Y1,…,Y10。
以上该程序功能为计算下列各式:
Z1=X1+Y1Z2=X2+Y2Z3=X3-Y3Z4=X4-Y4Z5=X5-Y5
Z6=X6+Y6Z7=X7-Y7Z8=X8-Y8Z9=X9+Y9Z10=X10+Y10
并将结果存入Z数组。
程序参考流程图:
微机原理与应用试题2答案
一、填空(每空1分,共8分)
1.标志寄存器中的6个状态位分别是SF、ZF、CF、AF、OF、PF。
2.8086/8088CPU内存最大寻址范围为1M字节。
3.设某存储芯片内有1024个单元,若用单译码方式,地址译码器将有1024条输出线;若使用双译码器方式,用两个相同的译码器,共需要64条译码输出线。
4.某芯片采用的是地址复用技术,共有七条地址引脚。
若它的首地址是0000H,则其末地址为3FFFH。
5.MOS型半导体随机存储器可分为SRAM和DRAM两种,后者在使用过程中每2mS内要刷新一次。
6.软中断指令INT20H的中断服务程序的入口地址在地址为:
80H—83H四个内存单元中。
二、(10分)改正下列有错误的指令
1.IN200H,AL5.DIVAX,59.MOVBYTEPTR[BX],256
2.MOVES,6000H6.SALAL,210.PPDB56,78,……
3.LOOPADD7.MOVDX,2000HMOVAX,PP
4.LEADI,[AX]8.PUSHCH11.CMP[DX],80H
解:
1.MOVDX,200H;
INAL,DX;
(或者:
OUTDX,AL)
(或者:
IN20H,AL)
2.MOVAX,6000H;
MOVES,AX
3.LOOPADD1
4.LEADI,[SI]
5.MOVBL,5;
DIVBL
6.MOVCL,2
SALAL,CL
7.正确
8.PUSHCX
9.MOVWORDPTR[BX],256
10.PPDB56,78,……
MOVAL,PP
11.MOVBX,DX
CMP[BX],80H
三.简答题
(1)(5分)试说明8086/8088工作在最小方式下和最大方式下系统基本配置的差别。
在最大组态下,8086/8088的外围电路由哪些器件组成?
它们的作用是什么?
解:
8086/8088工作在最大方式下时,需要使用8288总线控制器,但是工作在最小方式下时不需要使用。
8086/8088工作在最大方式下时,外围电路包括8284