8086/8088寻址与指令系统解析及练习

需积分: 35 27 下载量 159 浏览量 更新于2024-09-13 4 收藏 104KB DOC 举报
"8086寻址方式及指令系统练习题" 8086/8088微处理器的寻址方式和指令系统是理解其工作原理的关键部分。以下是相关知识点: 1. 寻址方式: - **寄存器寻址**:使用CPU内部的寄存器直接作为操作数,例如题目中的`AL`和`BX`。 - **直接寻址**:指令中直接给出操作数的物理地址,如`[BX]`。 - **寄存器间接寻址**:通过一个寄存器来间接指向内存中的操作数,如`[BX+SI]`。 - **基址变址寻址**:结合基址寄存器(如`BX`)和变址寄存器(如`SI`)计算地址。 - **段内间接寻址**:仅改变IP寄存器,用于段内的跳转。 - **段间间接寻址**:涉及CS和IP寄存器的改变,用于跨段跳转。 2. 指令系统: - **数据传送指令**:如`MOV`,用于在寄存器和内存之间传输数据。 - **算术运算指令**:包括加法`ADD`、减法`SUB`、乘法`IMUL`、除法`DIV`等,它们可能影响标志寄存器(如CF、OF)。 - **逻辑运算指令**:如`AND`、`OR`、`XOR`,不改变标志寄存器的某些位,如CF。 - **位操作指令**:如`SHL`、`SHR`,进行左移或右移操作,影响标志寄存器。 - **控制转移指令**:包括条件和无条件跳转,如`JMP`、`JNC`、`JA`等,根据标志寄存器状态决定执行路径。 - **串操作指令**:如`SCASB`,用于按字节比较内存和累加器,`CMPSW`进行字的比较。 - **堆栈操作指令**:如`PUSHA`、`POP AX`,处理堆栈中的数据。 3. BCD码: - **压缩型BCD码**:每个字节存储两位十进制数字,如74H对应十进制74。 - **非压缩型BCD码**:每个数字占用一个字节,如85H对应十进制85。 4. 进位和溢出标志: - **CF**(Carry Flag):在算术运算中用于表示是否发生进位。 - **OF**(Overflow Flag):标识是否发生溢出,对于两个有符号数的运算,当结果无法用当前数据类型表示时设置。 5. 段寄存器: - **CS**(Code Segment)、**DS**(Data Segment)、**SS**(Stack Segment)、**ES**(Extra Segment)用于指定不同段的起始地址,配合偏移量形成物理地址。 6. 数据处理: - 在进行补码运算时,例如题目中的9CH和7AH相加,需要考虑溢出和进位的情况。 - `DAA`指令用于辅助调整AL寄存器中的数值,使其符合ASCII码格式,常用于处理加法后的结果。 7. 指令执行: - 某些指令会改变标志寄存器的状态,如`ADD`、`SHL`,而其他如`MOV`通常不会影响标志寄存器。 以上是8086/8088寻址方式和指令系统的部分核心概念,这些知识对于理解和编程8086微处理器至关重要。