《微机原理与接口技术》复习参考资料1(4)

2019-04-23 07:49

(AH)←(AX) / (SRC) 的余数

字操作 (AX) ←(DX, AX) / (SRC) 的商

(DX) ←(DX, AX) / (SRC) 的余数

指令例子:

DIV CL

DIV WORD PTR[BX]

(2)有符号数除法指令IDIV 格式: IDIV src

操作与DIV类似。商及余数均为有符号数,且余数符号总是与被除数符号相同。 注意: 对于DIV/IDIV指令

AX(DX,AX)为隐含的被除数寄存器。 AL(AX)为隐含的商寄存器。 AH(DX)为隐含的余数寄存器。 src不能为立即数。

对所有条件标志位均无定

关于除法操作中的字长扩展问题

?除法运算要求被除数字长是除数字长的两倍,若不满足则需对被除数进行扩展,否则产生错误。

?对于无符号数除法扩展,只需将AH或DX清零即可。

?对有符号数而言,则是符号位的扩展。可使用前面介绍过的符号扩展指令CBW和CWD

三、逻辑运算和移位指令 1、逻辑运算指令 (1)逻辑与AND

对两个操作数进行按位逻辑“与”操作。 格式:AND dest, src

用途:保留操作数的某几位,清零其他位。

例1:保留AL中低4位,高4位清0。

AND AL,0FH

(2)逻辑或OR

对两个操作数进行按位逻辑‖或‖操作。 格式:OR dest, src

用途:对操作数的某几位置1;对两操作数进行组合。

例1:把AL中的非压缩BCD码变成相应十进制数的ASCII码。

OR AL, 30H

(3)逻辑非NOT

对操作数进行按位逻辑‖非‖操作。格式:NOT mem/reg

例:NOT CX

NOT BYTE PTR[DI]

(4)逻辑异或XOR

对两个操作数按位进行”异或”操作。 格式:XOR dest, src

用途:对reg清零(自身异或)

把reg/mem的某几位变反(与’1’异或)

例1:把AX寄存器清零。

①MOV AX,0 ②XOR AX,AX ③AND AX,0 ④SUB AX,AX

(5)测试指令TEST

操作与AND指令类似,但不将‖与‖的结果送回,只影响标志位。 TEST指令常用于位测试,与条件转移指令一起用。 例:测试AL的内容是否为负数。

TEST AL,80H ;检查AL中D7=1? JNZ MINUS ;是1(负数),转MINUS

… … ;否则为正数

2、移位指令

(1)非循环移位指令(重点?)

算术左移指令 SAL(Shift Arithmetic Left) 算术右移指令 SAR(Shift Arithmetic Right) 逻辑左移指令 SHL(Shift Left) 逻辑右移指令 SHR(Shift Right) 这4条指令的格式相同,以SAL为例:

CL ;移位位数大于1时

SAL mem/reg

1 ;移位位数等于1时

?算术移位——把操作数看做有符号数; 逻辑移位——把操作数看做无符号数。

?移位位数放在CL寄存器中,如果只移1位,也 可以直接写在指令中。例如: MOV CL,4 SHR AL,CL ;AL中的内容右移4位 ?影响C,P,S,Z,O标志。 ?结果未溢出时:

左移1位≡操作数*2

右移1位≡操作数/2

例:把AL中的数x乘10

因为10=8+2=23+21,所以可用移位实现乘10操作。程序如下:

MOV CL,3

SAL AL,1 ; 2x MOV AH,AL SAL AL,1 ; 4x

SAL AL,1 ; 8x

ADD AL,AH ; 8x+2x = 10x

移位指令的题目见综合练习题P6 五,4题;P21 五,1题

四、控制转移指令 1、 转移指令

(1)无条件转移指令JMP 格式:JMP label

本指令无条件转移到指定的目标地址,以执行从该地址开始的程序段。 (2)条件转移指令(补充内容)(重点?) ① 根据单个标志位设置的条件转移指令 JB/JC ;低于,或CF=1,则转移

JNB/JNC/JAE ;高于或等于,或CF=0,则转移 JP/JPE ;奇偶标志PF=1(偶),则转移 JNP/JPO ;奇偶标志PF=0(奇),则转移 JZ/JE ;结果为零(ZF=1),则转移 JNZ/JNE ;结果不为零(ZF=0),则转移 JS ;SF=1,则转移 JNS ;SF=0,则转移 JO ;OF=1,则转移 JNO ;OF=0,则转移 ②根据组合条件设置的条件转移指令 这类指令主要用来判断两个数的大小。 ??判断无符号数的大小 ?JA 高于则转移

条件为: CF=0∧ZF=0,即A>B ?JNA/JBE 低于或等于则转移

条件为: CF=1∨ZF=1,即A?B ?JB A

★判断有符号数的大小??JG ;大于则转移(A>B)

条件为: (SF⊕OF=0)∧ZF=0 ?JGE;大于或等于则转移(A?B)

条件为: (SF⊕OF=0)∨ZF=1?JLE;小于或等于则转移(A?B) 条件为: (SF⊕OF=1)∨ZF=1 ?JL;小于则转移(A<B=

条件为: (SF⊕OF=1)∧ZF=0

2、循环控制指令

?用在循环程序中以确定是否要继续循环。 ?循环次数通常置于CX中。

?转移的目标应在距离本指令-128~+127的范围之内。 ?循环控制指令不影响标志位。

(1)LOOP

格式:LOOP label 操作:(CX)-1→CX;

若(CX)≠0,则转至label处执行;

否则退出循环,执行LOOP后面的指令。 LOOP指令与下面的指令段等价: DEC CX JNZ label

3、过程调用指令 (1)调用指令CALL

一般格式:CALL sub ;sub为子程序的入口

4、中断指令

(1)INT n 执行类型n的中断服务程序,N=0~255

五、处理器控制指令 1、标志位操作 (1)CF设置指令

CLC 0→CF STC 1→CF CMC CF变反 (2)DF设置指令

CLD 0→DF (串操作的指针移动方向从低到高)

STD 1→DF (串操作的指针移动方向从高到低) (3)IF设置指令 CLI 0→IF (禁止INTR中断) STI 1→IF (开放INTR中断)

2、 HLT(halt)

执行HLT指令后,CPU进入暂停状态。

第四章 8086汇编语言程序设计

第一节 伪指令(重点?)

CPU指令与伪指令之间的区别:

(1)CPU指令是给CPU的命令,在运行时由CPU执行,每条指令对应CPU的一种特定的操作。而伪指令是给汇编程序的命令,在汇编过程中由汇编程序进行处理。

(2)汇编以后,每条CPU指令产生一一对应的目标代码;而伪指令则不产生与之相应的目标代码。

1、数据定义伪指令

(1)数据定义伪指令的一般格式为: ?[变量名] 伪指令 操作数[,操作数…] DB 用来定义字节(BYTE)

DW 用来定义字(WORD) DD 用来定义双字(DWORD)

(2)操作数的类型可以是: ①常数或常数表达式

?例如: DATA_BYTE DB 10,5,10H DATA_WORD DW 100H,100,-4 DATA_DW DD 2*30,0FFFBH ?可以为字符串(定义字符串最好使用DB) ?例如:char1 DB ?AB? ?可以为变量

?可以为?号操作符


《微机原理与接口技术》复习参考资料1(4).doc 将本文的Word文档下载到电脑 下载失败或者文档不完整,请联系客服人员解决!

下一篇:大豆孢囊线虫病的发生及防治

相关阅读
本类排行
× 注册会员免费下载(下载后可以自由复制和排版)

马上注册会员

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: