微机原理与接口技术试题库含答案样本.doc
《微机原理与接口技术试题库含答案样本.doc》由会员分享,可在线阅读,更多相关《微机原理与接口技术试题库含答案样本.doc(51页珍藏版)》请在咨信网上搜索。
资料内容仅供您学习参考,如有不当或者侵权,请联系改正或者删除。 三、 选择题 1、 在计算机内部, 一切信息的存取、 处理和传送都是以 D 形式进行的。 A) EBCDIC码 B) ASCII码 C) 十六进制编码 D) 二进制编码 2、 与十进制数56等值的二进制数是 A 。 A) 111000 B) 111001 C) 101111 D) 110110 四、 是非判断题 1、 在第三代计算机期间出现了操作系统。 ( √ ) 2、 对于种类不同的计算机, 其机器指令系统都是相同的。( × ) 3、 在计算机中, 数据单位bit的意思是字节。 ( × ) 1. 微处理器, 微型计算机和微型计算机系统三者之间有何区别? 答: 微处理器即CPU, 它包括运算器、 控制器、 寄存器阵列和内部总线等部分, 用于实现微型计算机的运算和控制功能, 是微型计算机的核心; 一台微型计算机由微处理器、 内存储器、 I/O接口电路以及总线构成; 微型计算机系统则包括硬件系统和软件系统两大部分, 其中硬件系统又包括微型计算机和外围设备; 由此可见,微处理器是微型计算机的重要组成部分, 而微型计算机系统又主要由微型计算机作为其硬件构成。 2. CPU在内部结构上由哪几部分构成? CPU应具备哪些主要功能? 答: CPU在内部结构上由运算器、 控制器、 寄存器阵列和内部总线等各部分构成, 其主要功能是完成各种算数及逻辑运算, 并实现对整个微型计算机控制, 为此, 其内部又必须具备传递和暂存数据的功能。 3. 累加器和其它通用寄存器相比有何不同? 答: 累加器是通用寄存器之一, 但累加器和其它通用寄存器相比又有其独特之处。累加器除了可用做通用寄存器存放数据外, 对某些操作, 一般操作前累加器用于存放一个操作数, 操作后, 累加器用于存放结果。 4. 微型计算机的总线有哪几类? 总线结构的特点是什么? 答: 微型计算机的总线包括地址总线、 数据总线和控制总线三类, 总线结构的特点是结构简单、 可靠性高、 易于设计生产和维护, 更主要的是便于扩充。 6. 计算机I/O接口有何用途? 试列出8个I/O接口。 答: 计算机I/O接口是连接计算机和外部设备的纽带和桥梁, 它主要用于协调和控制计算机与外设之间的信息流通和交换。例如: 串行通讯口( COM口) 、 并行打印机口、 软盘驱动器接口、 硬盘驱动器接口、 光驱接口、 显示器接口、 音响设备接口、 其它通用设备接口( USB、 SCSI等) 。 7. 现在, 计算机主板上一般都包括哪些I/O接口? I/O接口卡如何与主板相连? 答: 现在, 计算机主板上一般包括串行通讯口、 并行打印口、 软盘驱动器接口、 硬盘驱动器接口、 光驱接口、 USB接口等。象显示器适配器、 网卡、 modem卡等I/O接口卡一般经过总线插槽与主板相连。 8. 简述系统总线, AGP总线, PCI总线及ISA总线的作用。 答: 系统总线是CPU与存储器及桥接器之间传递信息的通道, AGP总线专门用与连接CPU与显示器适配器, PCI总线一般用于连接一些高速外设接口作为高速外设与CPU或内存交换信息的通道, 而ISA总线一般用于连接一些非高速外设接口作为非高速外设与CPU或内存交换信息的通道。 9. 试说明计算机用户, 计算机软件, 计算机硬件三者的相互关系。 答: 计算机用户, 计算机软件系统, 计算机硬件系统共同构成一个计算机应用系统, 三者在该系统中处于三个不同的层次。计算机用户处于最高层, 计算机软件处于中间层, 计算机硬件系统处于最下层。在这里计算机用户是系统的主宰, 她们经过软件系统与硬件系统发生关系, 指挥计算机硬件完成指定的任务。即, 计算机用户使用程序设计语言编制应用程序, 在系统软件的干预下使用硬件系统进行工作。 11. 存储单元的选择由什么信号控制? 读、 写靠什么信号区分? 答: 存储单元的选择由地址信号控制, 而对存储单元进行读操作还是写操作则要靠读、 写信号区分。 4.若用一个字节来表示带符号数, 判断下列各运算在机内进行时是否会产生溢出, 写出判断过程。 A. 5BH+32H; B. -08H-15H; C. -51H+(-3DH); D. 2DH+3CH 答: A. 产生溢出, 5BH=01011011B其补码表示的机器数为:01011011 32H=00110010B其补码表示的机器数为:00110010 相加的结果为:10001101 数值最高位向符号位进位,但符号位向前无进位,故产生溢出。 B. 不产生溢出, -08H=-00001000B其补码表示的机器数为:11111000 -15H=-00010101B其补码表示的机器数为:11101011 相加的结果为: 数值最高位向符号位进位,符号位同时也向前进位,故不产生溢出. C.产生溢出,-51H=-01010001B其补码表示的机器数为:10101111 -3DH=-00111101B其补码表示的机器数为:11000011 相加的结果为: 数值最高位向符号位无进位,但符号位向前进位,故产生溢出. D.不产生溢出,2DH=00101101B其补码表示的机器数为:00101101 3CH=00111100B其补码表示的机器数为:00111100 相加的结果为:01101001 数值最高位向符号位无进位,符号位向前也无进位,故不产生溢出。 6.详细叙述总线缓冲器的作用。 答: 总线缓冲器的作用主要是控制各路数据在总线上的交叉传送避免相互冲突, 当几路数据都要向总线上传送时, 就经过各路的缓冲器来解决, 当一路传送时, 缓冲器使其它各路数据与总线断开。 7.锁存器和寄存器有什么不同? 答: 锁存器与寄存器都是用来暂存数据的器件, 在本质上没有区别, 不过寄存器的输出端平时不随输入端的变化而变化, 只有在时钟有效时才将输入端的数据送输出端( 打入寄存器) , 而锁存器的输出端平时总随输入端变化而变化, 只有当锁存器信号到达时, 才将输出端的状态锁存起来, 使其不再随输入端的变化而变化。 1.8086从功能上分成了EU和BIU两部分。这样设计的优点是什么? 答: 传统计算机在执行程序时, CPU总是相继地完成取指令和执行指令的动作, 即, 指令的提取和执行是串行进行的。而8086CPU 在功能上分成了EU和BIU两部分, BIU负责取指令, EU负责指令的执行, 它们之间既互相独立又互相配合, 使得8086能够在执行指令的同时进行取指令的操作, 即实现了取指令和执行指令的并行工作, 大大提高了CPU和总线的利用率, 从而提高了指令的处理速度。 2.8086 CPU中地址加法器的重要性体现在哪里? 答: 地址加法器是8086 CPU的总线接口单元中的一个器件, 在8086存储器分段组织方式中它是实现存储器寻址的一个关键器件, 地址加法器将两个16位寄存器中的逻辑地址移位相加, 得到一个20位的实际地址, 把存储器寻址空间从64K扩大到1M, 极大地扩大了微型计算机的程序存储空间, 从而大大提高了程序运行效率。 3.8086 CPU中有哪些寄存器? 分组说明用途。哪些寄存器用来指示存储器单元的偏移地址? 答: 8086 CPU中有8个通用寄存器AX、 BX、 CX、 DX、 SP、 BP、 SI、 DI; 两个控制寄存器IP、 FL; 四个段寄存器CS、 DS、 SS、 ES。8个通用寄存器都能够用来暂存参加运算的数据或中间结果, 但又有各自的专门用途。例如, AX专用做累加器, 某些指令指定用它存放操作数和运算结果; CX为计数寄存器, 在某些指令中做计数器使用; DX为数据寄存器; BX为基址寄存器, BP为基址指针, SI为源变址寄存器, DI为目的变址寄存器, 这4个寄存器在数据寻址中用来存放段内偏移地址( 有效地址) 或段内偏移地址的一部分; SP为堆栈指示器, 用来存放栈顶有效地址。两个控制寄存器用来存放有关的状态信息和控制信息。例如, 标志寄存器FL用来存放状态标志和控制标志; 而指令指针用来存放下一条要取指令的有效地址。四个段寄存器用来存放段地址。例如, CS寄存器用来存放代码段的段地址; DS寄存器用来存放数据段的段地址; SS寄存器用来存放堆栈段的段地址; ES寄存器用来存放扩展段的段地址。 4.8086系统中存储器的逻辑地址由哪两部分组成? 物理地址由何器件生成? 如何生成? 每个段的逻辑地址与寄存器之间有何对应关系? 答: 8086系统中存储器的逻辑地址由段地址( 段首址) 和段内偏移地址( 有效地址) 两部分组成; 存储单元的物理地址由地址加法器生成, 寻址时, CPU首先将段地址和段内偏移地址送入地址加法器, 地址加法器将段地址左移4位并与段内偏移地址相加, 得到一个20位的物理地址。数据段的段地址在DS寄存器中, 段内偏移地址可能在BX、 BP、 SI或DI寄存器中。代码段的段地址在CS寄存器中, 段内偏移地址在IP寄存器中。堆栈段的段地址在SS寄存器中, 段内偏移地址在SP寄存器中。扩展段的段地址在ES寄存器中, 段内偏移地址可能在BX、 BP、 SI或DI寄存器中。 5.设CPU中各有关寄存器的当前状况为: SS=0a8bH、 DS=17ceH、 CS=dc54H、 BX=394bH、 IP=2f39H、 SP=1200H, BX 给出的是某操作数的有效地址, 请分别写出该操作数、 下一条要取的指令及当前栈顶的逻辑地址和物理地址。 答: 该操作数的逻辑地址为DS: BX=17CE: 394BH, 物理地址=17CEH*10H+394BH=1B62BH; 下一条要取的指令的逻辑地址为CS: IP=DC54: 2F39H, 物理地址=DC54H*10H+2F39H=DF479H; 当前栈顶的逻辑地址=SS: SP=0A8B: 1200H, 物理地址=0A8BH*10H+1200H=0BAB0H。 6.若DS=157DH时, 某操作数的物理地址是215FAH, 当DS=18DEH时, 该操作数的物理地址是多少? 答: 该操作数的段内偏移地址=该操作数的物理地址-DS=215FAH-157D0H=BE2AH, 故当DS=18DEH时, 该操作数的物理地址=DS*10H+BE2AH=18DE0H+BE2AH=24C0AH 7.设 AX=2875H、 BX=34DFH、 SS=1307H、 SP=8H, 依此执行 PUSH AX、 PUSH BX、 POP AX、 POP CX后栈顶指针变为多少? AX=? BX=? CX=? 答: 当前栈顶指针=SS*10H+SP=13070H+8H=13078H, 依此执行PUSH AX、 PUSH BX、 POP AX、 POP CX后栈顶指针仍为13078H。但AX=34DFH, BX=34DFH, CX=2875H。 1. 假定( BX) =637DH, ( SI) =2A9BH, 位移量D=3237H, 试确定在以下各种寻址方式下的有效地址是什么? ( 1) 立即寻址 ( 2) 直接寻址 ( 3) 使用BX的寄存器寻址 ( 4) 使用BX的间接寻址 ( 5) 使用BX的寄存器相对寻址 ( 6) 基址变址寻址 ( 7) 相对基址变址寻址 答: ( 1) 立即数寻址的有效地址是当前IP的内容; ( 2) 直接寻址, 若使用位移量D=3237H进行, 则有效地址为3237H; ( 3) 使用BX的寄存器寻址时, 操作数在BX寄存器中, 因此无有效地址; ( 4) 使用BX的间接寻址时, 有效地址在BX寄存器中, 即有效地址=637DH; ( 5) 使用BX的寄存器相对寻址的有效地址=( BX) +D=637DH+3237H=95B4H; ( 6) 基址变址寻址的有效地址=( BX) +( SI) =637DH+2A9BH=8E18H; ( 7) 相对基址变址寻址的有效地址=( BX) +( SI) +D=C050H; 2. 写出把首地址为BLOCK的字数组的第6个字送到DX寄存器的指令。要求使用以下几种寻址方式: ( 1) 寄存器间接寻址 ( 2) 寄存器相对寻址 ( 3) 基址变址寻址 答: ( 1) 使用寄存器间接寻址, 把首地址为BLOCK的字数组的第6个字送到DX寄存器的指令为: MOV BX, BLOCK ADD BX, 12 MOV DX, [BX] ( 2) 使用寄存器相对寻址, 把首地址为BLOCK的字数组的第6个字送到DX寄存器的指令为: MOV BX, BLOCK MOV DX, [BX+12] ( 3) 使用基址变址寻址, 把首地址为BLOCK的字数组的第6个字送到DX寄存器的指令为: MOV BX, BLOCK MOV SI, 12 MOV DX, [BX+SI] 3. 现有(DS)= H, (BX)=0100H, (SI)=0002H, ( 0H)=12H, ( 1H)=34H, ( 2H)=56H, ( 3H)=78H, (21200H)=2AH, (21201H)=4CH, (21202H)=B7H, (21203H)=65H, 试说明下列各条指令执行完后AX寄存器的内容。 ( 1) MOV AX, 1200H ( 2) MOV AX, BX ( 3) MOV AX, [1200H] ( 4) MOV AX, [BX] ( 5) MOV AX, [BX+1100] ( 6) MOV AX, [BX+SI] ( 7) MOV AX, [BX+SI+1100] 答: ( 1) 指令MOV AX, 1200H执行完后AX寄存器的内容为1200H; ( 2) 指令MOV AX, BX执行完后AX寄存器的内容为0100H; ( 3) 指令MOV AX, [1200H]是将从物理地址=( DS) *10H+1200H=21200H开始的两个单元内容送AX, 执行完后AX寄存器的内容为4C2AH; ( 4) 指令MOV AX, [BX]是将从物理地址=( DS) *10H+( BX) = 0H开始的两个单元内容送AX, 故执行完后AX寄存器的内容为3412H; ( 5) 指令MOV AX, [BX+1100]是将从物理地址=( DS) *10H+( BX) +1100H=21200H开始的两个单元内容送AX, 故执行完后AX寄存器的内容为4C2AH; ( 6) 指令MOV AX, [BX+SI]是将从物理地址=( DS) *10H+( BX) +( SI) = 2H开始的两个单元内容送AX, 故执行完后AX寄存器的内容为7856H; ( 7) 指令MOV AX, [BX+SI+1100]是将从物理地址=( DS) *10H+( BX) +( SI) +1100H=21202H开始的两个单元内容送AX, 故执行完后AX寄存器的内容为65B7H; 4.假设已知(DS)=2900H,(ES)=2100H,(SS)=1500H,(SI)=00A0H,(BX)= 0100H, (BP)=0010H, 数据段中变量名VAL的偏移地址值为0050H, 试指出下列源操作数字段的寻址方式是什么? 其物理地址值是多少? ( 1) MOV AX, 0ABH ( 2) MOV AX, BX ( 3) MOV AX, [100H] ( 4) MOV AX, VAL ( 5) MOV AX, [BX] ( 6) MOV AX, ES:[BX] ( 7) MOV AX, [BP] ( 8) MOV AX, [SI] ( 9) MOV AX, [BX+10] ( 10) MOV AX, VAL[BX] ( 11) MOV AX, [BX][SI] ( 12) MOV AX, [BP][SI] 答: ( 1) 在指令 MOV AX, 0ABH 中, 源操作数字段的寻址方式是立即数寻址, 其物理地址值=( CS) *10H+( IP) ; ( 2) 在指令 MOV AX, BX 中, 源操作数字段的寻址方式是寄存器寻址, 操作数在BX中, 无物理地址; ( 3) 在指令 MOV AX, [100H] 中, 源操作数字段的寻址方式是直接寻址, 其物理地址值=( DS) *10H+100 =29000H+100H=29100; ( 4) 在指令 MOV AX, VAL 中, 源操作数字段的寻址方式是直接寻址, 其物理地址值=( DS) *10H+50H =29000H+50H=29050H; ( 5) 在指令 MOV AX, [BX] 中, 源操作数字段的寻址方式是寄存器间接寻址, 其物理地址值=( DS) *10H +( BX) =29000H+100H=29100H; ( 6) 在指令 MOV AX, ES: [BX] 中, 源操作数字段的寻址方式是寄存器间接寻址, 其物理地址值=( ES) *10H+( BX) =21000H+100H=21100H; ( 7) 在指令 MOV AX, [BP] 中, 源操作数字段的寻址方式是寄存器间接寻址, 其物理地址值=( SS) *10H +( BP) =15000H+10H=15010H; ( 8) 在指令 MOV AX, [SI] 中, 源操作数字段的寻址方式是寄存器间接寻址, 其物理地址值=( DS) *10H +( SI) =29000H+0A0H=290A0H; ( 9) 在指令 MOV AX, [BX+10] 中, 源操作数字段的寻址方式是寄存器相对寻址, 其物理地址值=( DS) *10H+( BX) +0AH= 29000H+100H+0AH =2910AH; ( 10) 在指令 MOV AX, VAL[BX] 中, 源操作数字段的寻址方式是寄存器相对寻址, 其物理地址值=( DS) *10H+( BX) +50H= 29000H+100H+50H= 29150H; ( 11) 在指令 MOV AX, [BX][SI] 中, 源操作数字段的寻址方式是基址变址寻址, 其物理地址值=( DS) *10H+( BX) +( SI) =29000H+100H+0A0H =291A0H; ( 12) 在指令 MOV AX, [BP][SI] 中, 源操作数字段的寻址方式是基址变址寻址, 其物理地址值=( SS) *10H+( BP) +( SI) =15000H+10H+0A0H =150B0H 5.分别指出下列指令中的源操作数和目的操作数的寻址方式。 ( 1) MOV SI, 200 ( 2) MOV CX, DATA[SI] ( 3) ADD AX, [BX+DI] ( 4) AND AX, BX ( 5) MOV [SI], AX ( 6) PUSHF 答: ( 1) 目的操作数字段的寻址方式是寄存器寻址, 源操作数字段的寻址方式是立即数寻址; ( 2) 目的操作数的寻址方式是寄存器寻址, 源操作数的寻址方式是寄存器相对寻址; ( 3) 目的操作数的寻址方式是寄存器寻址, 源操作数的寻址方式是基址变址寻址; ( 4) 目的操作数的寻址方式是寄存器寻址, 源操作数的寻址方式也是寄存器寻址; ( 5) 目的操作数的寻址方式是寄存器间接寻址, 源操作数的寻址方式是寄存器寻址; ( 6) 目的操作数的寻址方式是寄存器间接寻址, 源操作数的寻址方式是寄存器寻址; 6.试述指令MOV AX, H和MOV AX, DS:[ H] 的区别。 答: 指令MOV AX, H是将立即数 H送AX寄存器, 而指令MOV AX, DS:[ H]是将DS段有效地址为 H的两个单元的内容送AX。 7.写出以下指令中内存操作数的所在地址。 ( 1) MOV AL, [BX+5] ( 2) MOV [BP+5], AX ( 3) INC BYTE PTR [SI+3] ( 4) MOV DL, ES:[BX+DI] ( 5) MOV BX, [BX+SI+2] 答: ( 1) 指令MOV AL, [BX+5]中内存操作数的所在地址=( DS) *10H+( BX) +5; ( 2) 指令MOV [BP+5], AX中内存操作数的所在地址=( SS) *10H+( BP) +5和( SS) *10H+( BP) +6; ( 3) 指令INC BYTE PTR[SI+3]中内存操作数的所在地址=( DS) +( SI) +3; ( 4) 指令MOV DL, ES:[BX+DI]中内存操作数的所在地址=( ES) *10H+( BX) +( DI) ; ( 5) 指令MOV BX, [BX+SI+2]中内存操作数的所在地址=( DS) *10H+( BX) +( SI) +2和( DS) *10H+( BX) +( SI) +3; 8.判断下列指令书写是否正确, 如有错误, 指出错在何处并用正确的程序段( 一条或多条指令) 实现原错误指令((8)、 (13)除外)期望实现的操作。 ( 1) MOV AL, BX ( 9) MOV ES, 3278H ( 2) MOV AL, SL ( 10) PUSH AL ( 3) INC [BX] ( 11) POP [BX] ( 4) MOV 5, AL ( 12) MOV [1A8H], 23DH ( 5) MOV [BX], [SI] ( 13) PUSH IP ( 6) MOV BL, F5H ( 14) MOV [AX], 23DH ( 7) MOV DX, H ( 15) SHL AX, 5 ( 8) POP CS ( 16) MUL AX, BX 答: ( 1) MOV AL,BX 错, 源操作数为字类型, 目的操作数为字节类型, 二者不一致。应改为: MOV AX,BX 或 MOV AL,BL ; ( 2) MOV AL,SL 错, SI寄存器不能分为高8位和低8位使用, 即没有SL寄存器。应改为: MOV AX,SI ( 3) INC [BX] 错, 未指定操作数的类型。应改为: INC BYTE PTR [BX] ( 4) MOV 5,AL 错, 目的操作数使用了立即数, 在指令中一般不允许。应改为: MOV DS:[5],AL ( 5) MOV [BX],[SI] 错, 源操作数和目的操作数均为内存单元, 不允许。 应改为: MOV AX,[SI] MOV [BX],AX ( 6) MOV BL,F5H 错, 源操作数错, 以A~F开头的数字前应加0。应改为: MOV BL,0F5H ( 7) MOV DX, H 正确。 ( 8) POP CS 错, 不能将栈顶数据弹至CS中。 ( 9) MOV ES, 3278H 错, 立即数不能直接送ES寄存器。 应改为: MOV AX,3278H MOV ES,AX ( 10) PUSH AL 错, 栈操作不能按字节进行。应改为: PUSH AX ( 11) POP [BX] 正确。 ( 12) MOV [1A8H],23DH 错, 源操作数是立即数, 目的操作数必须使用寄存器指出。应改为: MOV BX, 1A8H MOV [BX],23DH ( 13) PUSH IP 错, 不能用IP寄存器做源操作数。 ( 14) MOV [AX],23DH 错, 不能用AX寄存器间接寻址。应改为: MOV BX, AX MOV [BX], 23DH ( 15) SHL AX,5 错, 不能用大于己于1的立即数指出移位位数。应改为: MOV CL, 5 SHL AX, CL ( 16) MUL AX,BX 错, 目的操作数AX是隐含的, 不能在指令中写出。应改为: MUL BX 9.设堆栈指针SP的初值为 H, AX=3000H, BX=5000H, 试问: ( 1) 执行指令PUSH AX后 (SP)=? ( 2) 再执行PUSH BX及POP AX后 (SP)=? (AX)=? (BX)=? 答: ( 1) 执行指令PUSH AX后 (SP)= H-2=1FFEH; ( 2) 再执行PUSH BX及POP AX后 (SP)=1FFEH, (AX)=5000H, (BX)=5000H 10.要想完成把[ H]送[1000H]中, 用指令:MOV [1000H], [ H]是否正确? 如果不正确, 应用什么方法? 答: 把[ H]送[1000H]中, 用指令 MOV [1000H], [ H]不正确, 应改为: MOV AX,[ H] MOV [1000H],AX 11.假如想从200中减去AL中的内容, 用SUB 200, AL是否正确? 如果不正确, 应用什么方法? 答: 想从200中减去AL中的内容, 用SUB 200, AL不正确, 应改为: MOV BL,200 SUB BL,AL 12分别写出实现如下功能的程序段 (5)将数据段中以BX为偏移地址的连续四个单元的内容颠倒过来 答: (5) 将数据段中以BX为偏移地址的连续四个单元的内容颠倒过来的程序段是: MOV AL,[BX] ; 数据段中BX为偏移地址的字单元内容送AX XCHG AL,[BX+3] ; 数据段中BX+3为偏移地址的字单元内容与AX的内容交换 MOV [BX],AL ; 数据段中BX+3为偏移地址的字单元内容送BX为偏移地址的字单元 MOV AL,[BX+1] ; 数据段中BX+1为偏移地址的字单元内容送AX XCHG AL,[BX+2] ; 数据段中BX+2为偏移地址的字单元内容与AX的内容交换 MOV [BX+1],AL ; 数据段中BX+2为偏移地址的字单元内容送BX+1为偏移地址的字单元 1.假设OP1, OP2是已经用DB定义的变量, W_OP3和W_OP4是已经用DW定义的变量, 判断下列指令书写是否正确? 如有错误, 指出错在何处? 并写出正确的指令( 或程序段) 实现原错误指令期望实现的操作((19)、 (20)不改)。 (1)PUSH OP1 (2)POP [W_OP4] (3)MOV AX, WORD PTR [SI][DI] (4)MOV AX,WORD PTR ES:BX (5)MOV BYTE PTR [BX], 1000 (6)MOV BX, OFFSET [SI+200H] (7)MOV OP2,[BX] (8)CMP HIGH W_OP3, 25 (9)CMP OP1, OP2 (10)CMP AX, OP2 (11)MOV W_OP3[BX+4*3][DI], SP (12)ADD W_OP3, W_OP4 (13)MOV AX, W_OP3[DX] (14)MOV OP1, LOW DS (15)MOV SP, OP2[BX][SI] (16)MOV AX, W_OP3+W_OP4 (17)MOV AX,W_OP3-W_OP4+100 (18)SUB AL, W_OP3+7 (19)MOV AX,BX SHL 2 (20)MOV BX,W_OP3 AND 8FD7H 答: 1. (1)PUSH OP1 错, OP1为字节类型,栈操作不能按字节进行, 应改为:PUSH WORD PTR OP1 (2)POP [W_OP4] 正确。 (3)MOV AX, WORD PTR [SI][DI] 错, 源操作数寻址方式有问题。 应改为: MOV BX, SI MOV AX, WORD PTR [BX][DI] (4)MOV AX,WORD PTR ES:BX错, 若源操作数为寄存器寻址是不能加段说明及属性修改的。显然,原意应为寄存器间接寻址,故应改为: MOV AX,WORD PTR ES:[BX] (5)MOV BYTE PTR [BX], 1000 错, 源操作数为字类型, 目的操作数为字节类型, 二者不一致。应改为: MOV WORD PTR [BX], 1000 (6)MOV BX, OFFSET [SI+200H] 错, OFFSET运算应在汇编时完成,但[SI+200H]在执行指令时才可获得。应改为: LEA BX,[SI+200H] (7)MOV OP2,[BX] 错, 源操作数和目的操作数均为内存单元, 不允许。 应改为: MOV AL, [BX] MOV OP2, AL (8)CMP HIGH W_OP3, 25错, 目的操作数中使用HIGH来分离存储器操作数, 这是不允许的。应改为: CMP BYTE PTR W_OP3+1,25 (9)CMP OP1, OP2错, 源操作数和目的操作数均为内存单元, 不允许。 应改为: MOV AL, OP2 CMP AL, OP1 (10)CMP AX, OP2错, 源操作数为字节类型, 目的操作数为字类型, 二者不一致。 应改为: CMP AX, WORD PTR OP2 (11)MOV W_OP3[BX+4*3][DI], SP正确。 (12)ADD W_OP3, W_OP4错, 源操作数和目的操作数均为内存单元, 不允许。 应改为: MOV AX, W_OP4 ADD W_OP3, AX (13)MOV AX, W_OP3[DX] 错, 不能用DX寄存器间接寻址。 应改为: MOV BX, DX MOV AX, W_OP3[BX] (14)MOV OP1, LOW DS错, 源操作数中使用LOW来分离寄存器操作数, 这是不允许的。 应改为: MOV WORD PTR OP1,DS (15)MOV SP, OP2[BX][SI] 错, 源操作数为字节类型, 目的操作数为字类型, 二者不一致。应改为:MOV SP, WORD PTR OP2[BX][SI] (16)MOV AX, W_OP3+W_OP4错, 两个标识符相加无意义。应改为: MOV AX, W_OP1 ADD AX, W_OP2 (17)MOV AX,W_OP3-W_OP4+100正确,源操作数为两个标识符( 地址) 相减再加一数, 汇编时得到一个数。 (18)SUB AL, W_OP3+7错, 两个操作数类型不一致。应改为: SUB AL, BYTE PTR W_OP3+7 (19)MOV AX,BX SHL 2错, SHL只能对常量进行运算,左边不能使用寄存器 (20)MOV BX,W_OP3 AND 8FD7H错, AND只能对常量进行运算,左边不能使用变量 4.设已定义数据段 DATA SEGMENT …… VAR2 DW 10H, 7889H …… VAR5 DB 20H, 0 ADRR DW VAR2, VAR5 DATA ENDS 为使ADRR字存储单元中存放内容为”0010H”, ADRR+2字存储单元中存放内容为”0020H”, 上述省略号位置应分别填写一条什么语句? 说明理由。 答: 为使ADRR字存储单元中存放内容为”0010H”, ADRR+2字存储单元中存放内容为”0020H”, 上述省略号位置应分别填写ORG 10H 和 ORG 20H, 或者分别填写语句 VAR1 DB 10H DUP(?) 和 VAR3 6 DUP(?) 5.下面的数据段中, 有数据为‘4100H’的字存储单元有几个? 它们的偏移量分别是多少? DATA SEGMENT DA1 DB 0 ORG 41H DA2 DB 0, ‘A’, 41H, 0, 41H ADR DW DA1, DA2 DATA ENDS 答: 给出的数据段中, 有数据‘4100H’的字存储单元有3个,它们的偏移量分别是41H、 44H、 47H。 7.试用数据定义语句DB或DW改写下述两语句中的某一个, 使它们在存储器中有完全相同的存储情况。 VAR1 DB ‘abcdefghij’ VAR2 DW 6162H, 6364H, 6566H, 6768H, 696AH 答: 将第一个伪指令语句改写为VAR1 DW ‘ab’, ‘cd’, ‘ef’, ‘gh’, ‘ij’, 第二个伪指令语句不变。或第一个伪指令语句不变, 而将第二个伪指令语句改写为: VAR2 DB 61H, 62H, 63H, 64H, 65H, 66H, 67H, 68H, 69H, 6AH 9.按下面的要求写出程序的框架 (1)数据段的位置从0E000H开始, 数据段中定义一个100字节的数组, 其类型属性既是字又是字节; (2)- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 微机 原理 接口 技术 试题库 答案 样本
咨信网温馨提示:
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【二***】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【二***】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【二***】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【二***】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
关于本文