第4章 指令系统和寻址方式64.ppt_第1页
第4章 指令系统和寻址方式64.ppt_第2页
第4章 指令系统和寻址方式64.ppt_第3页
第4章 指令系统和寻址方式64.ppt_第4页
第4章 指令系统和寻址方式64.ppt_第5页
已阅读5页,还剩115页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、第4章 8086寻址方式与指令系统,4.1.1 指令格式,1. 指令 指令是计算机能够识别和执行的指挥计算机进行操作的命令。 指令系统是指微处理器能执行的各种指令的集合。不同的微处理器有不同的指令系统。 计算机指令码由操作码字段和操作数字段两部分组成。操作码字段指出所要执行的操作,而操作数字段指出指令操作过程中需要的操作对象。,4.1 8086寻址方式,例:一条加法指令的机器码为:02CFH = 000000 10 11001111,前6个0,表示加法操作,为操作码字段,剩余部分说明操作数。该指令的助记符为:ADD CL,BH,即实现:CL CL + BL。 操作数可以有一个、二个或更多,通常

2、分别称为单操作数指令(一地址指令)、双操作数指令 (二地址指令)。 ADD CL,BH 是双操作数指令; INC AL 是单操作数指令。 在双操作数指令格式中,提供两个操作数,分别称为目标操作数(左边的那个)和源操作数(右边的那个)。当指令执行时,两个操作数同时参与运算,并把运算结果返回目标操作数中,也就是说,目标操作数原有内容在运算后将会改变。,2.指令格式,3. 操作数 操作数是指令的操作对象。8086/8088指令系统中的操作数分为两类:数据操作数、转移地址操作数。 (1) 数据操作数 按存储位置,数据操作数分为:立即数、寄存器操作数、内存操作数、I/O操作数。 1) 立即数:指令中直接

3、给出操作数本身。 2) 寄存器操作数:即操作对象是寄存器中的内容。例上述指令中AL为寄存器操作数。,3) 内存操作数:也称为存储器操作数,操作对象是内存中的数。 4) I/O操作数:指令中要操作的数据来自或送到I/O端口。 (2) 转移地址操作数 这类操作数出现在程序跳转或程序调用指令中,指出程序要转移的目的地址。它也可以分为:立即数、寄存器操作数、存储器操作数,即要转移的目标地址包含在指令中或存放在寄存器、内存储器中。,4.1.2 数据寻址方式,指令中关于如何求出操作数有效地址的方法称为寻址方式。(换句话说,指出操作数的来源)。 计算机按照指令给出的寻址方式求出操作数有效地址的过程,称为寻址

4、操作。 8086给出了多种寻址方式,根据操作数的类型及来源大致分为三类:数据寻址、转移地址寻址、I/O寻址。,数据寻址方式:,1 立即寻址,立即寻址即指令中直接给出操作数本身。采用该寻址方式的操作数与指令代码一起存放在代码段中。 例:MOV AX ,1234H ;AX 1234H 注意:立即寻址通常用于双操作数指令中,且只能是源操作数。,执行过程如图所示:,2 寄存器寻址,寄存器寻址是指操作数存放在寄存器中,指令中给出寄存器名。 例:MOV DX ,AX ;DX AX 执行过程如图所示: 特点: (1)操作数在寄存器中,寄存器在CPU内部,指令执行时,操作就在CPU的内部进行,不需要访问存储器

5、来取得操作数,因而执行速度快。 (2)寄存器号比内存地址短,汇编后机器码长度短。 (3)寄存器寻址方式既可用于源操作数,也可用于目标操作数,还可以两者都用寄存器寻址方式。,注意: (1)当指令中的源操作数和目标操作数均为寄存器时,必须采用同样长度的寄存器; (2)两个操作数不能同时为段寄存器; (3)目标操作数不能是代码段寄存器(CS)。 除以上两种寻址方式外,下面5种寻址方式的操作数均在存储器中,统称为内存寻址方式。当采用内存操作数时,必须注意双操作数指令中的两个操作数不能同时为内存操作数。,3 直接寻址,直接寻址即指令中给出操作数所在存储单元的有效地址,缺省的段为数据段。为了区别于立即数,

6、有效地址用括起。 例:以下指令中源或目标操作数采用了直接寻址方式 (1) MOV AX,2000H ;AX (DS:2000H) (2) MOV 1200, BL ;(DS:1200H) BL (3) MOV ES:0100, AL ;(ES:0100H) AL 说明:DS:2000表示内存单元地址; (DS:2000)表示地址是DS:2000的内存单元内容。,【例】设 DS=4000H,(42000H)=12H,(42001H)=34H,执行指令 MOV AX,2000H后,AX = ? 根据指令中给出的有效地址得到存储单元的物理地址: DS 16 + 2000H = 42000H 把该内存

7、单元开始的两个字节的内容传送到AX中。低地址单元内容传送到AL中,高地址单元内容传送到AH中。 AX = 3412H 执行过程如图所示: 说明:直接寻址允许数据存于附加段、堆栈段、代码段,这称为“段超越”,此时,需要段说明,如例(3)中,数据存于附加段中,操作数物理地址为:ES10H + 0100H。,4 寄存器间接寻址,寄存器间接寻址是把内存操作数的有效地址存储于寄存器中,指令中给出存放地址的寄存器名。 8086/8088中可用于间接寻址的寄存器有基址寄存器BX、BP和变址寄存器SI、DI。为区别于寄存器寻址,寄存器名要用“”括起。 例:MOV AX,SI ;AX (DS:SI+1,DS:S

8、I),有效地址EA计算方法如下:,EA=,SISI作间址寄存器。 DIDI作间址寄存器。 BXBX作间址寄存器。 BPBP作间址寄存器。,物理地址PA计算方法如下: 物理地址 = DS 10H + SI 或 DI 或 BX 或 物理地址 = SS 10H + BP 注意:不同的寄存器所隐含对应的段不同。采用SI、DI、BX寄存器,数据存于数据段中;采用BP寄存器,数据存于堆栈段中。,【例】设 DS=3000H,SI=2000H,(32000H)=50H, (32001H)=40H,执行指令 MOV AX,SI后,AX = ? 根据指令中给出的寄存器及寄存器内容得到存储单元的物理地址: DS 1

9、6 + 2000H = 32000H 把该内存单元开始的两个字节的内容传送到AX中。低地址单元内容传送到AL中,高地址单元内容传送到AH中。 AX = 4050H 执行过程如图所示:,5 寄存器相对寻址,寄存器相对寻址是把指定的寄存器内容作为变址,与指令中给出的偏移量一起形成有效地址EA,操作数在存储器中。选用不同寄存器,对应的段不同,规律同寄存器寻址。 操作数的有效地址: EA1 = SI/DI/BX + 8位disp/16位disp(disp代表偏移量) 或 EA2 = BP + 8位disp/16位disp 操作数的物理地址: PA1 = DS 10H + EA1 或 PA2 = SS

10、10H + EA2,【例】设 DS=3000H,BX=0100H,(30108H)=12H,执行指令 MOV AL,8BX后,AL = ? 根据指令中给出的寄存器名、偏移量及寄存器内容,得到存储单元的物理地址: DS 16 + BX + disp = 30108H 把该内存单元中内容传送到AL中。 AL = 12H 执行过程如图所示:,说明: (1)偏移量是有符号数,8位偏移量的取值范围为:00FFH(即+127-128);16位偏移量的取值范围为:0000FFFFH(即+32765-32768)。 (2)IBM PC汇编允许用三种形式表示相对寻址,它们的效果是一样的,如: MOV AX,BX

11、+6 ;标准格式 MOV AX,6BX ;先写偏移值 MOV AX,BX+6 ;偏移值写在括号内,6 基址变址寻址,采用基址变址寻址时,操作数的有效地址分为两部分,一部分存于基址寄存器BX或BP中,另一部分存于变址寄存器SI或DI中,指令中分别给出两个寄存器名。操作数的有效地址为: EA1 = BX + SI / DI 或 EA2 = BP + SI / DI 当基址寄存器选用BX时,数据隐含存于数据段中;当基址寄存器选用BP时,数据隐含存于堆栈段中,即操作数的物理地址为: PA1 = DS 10H + EA1 或 PA2 = SS 10H + EA2,【例】设 SS=3000H,BP=010

12、0H,SI=5,(30105H)=78H,执行指令 MOV AL,BPSI后,AL = ? 根据指令中给出的寄存器名及寄存器内容,得到存储单元的物理地址: SS 16 + BP + SI = 30105H 把该内存单元中内容传送到AL中。 AL = 78H 执行过程如图所示:,7 相对基址变址寻址,采用相对基址变址寻址时,操作数的有效地址分为三部分,一部分存于基址寄存器BX或BP中;一部分存于变址寄存器SI或DI中;一部分为偏移量。指令中分别给出两个寄存器名及8位或16位的偏移量。操作数的有效地址为: EA1 = BX + SI/DI + 8位/16位 disp 或 EA2 = BP + SI

13、/DI + 8位/16位 disp 当基址寄存器选用BX时,数据隐含存于数据段中;当基址寄存器选用BP时,数据隐含存于堆栈段中,即操作数的物理地址为: PA1 = DS 10H + EA1 或 PA2 = SS 10H + EA2,【例】设 SS=2000H,BP=1000H,SI=0100H,(21105H)=78H,执行指令 MOV AL,5BPSI后,AL = ? 根据指令中给出的寄存器名及寄存器内容,得到存储单元的物理地址: SS 16 + BP + SI + disp = 21105H 把该内存单元中内容传送到AL中。 AL = 78H 执行过程如图所示:,4.2 8086指令系统,

14、8086/8088指令系统按其功能可分6类: 3.4.1. 数据传送指令 3.4.2. 算术运算指令 3.4.3. 逻辑指令 3.4.4. 串操作指令 3.4.5. 控制转移指令 3.4.6. 处理机控制指令,约定以下符号:,4.2.1 数据传送指令,1. 通用数据传送指令 2. 地址传送指令 3. 标志传送指令 4. 输入输出指令,数据传送指令,1 通用数据传送指令,(1) 传送指令MOV (2) 堆栈操作指令 (3) 数据交换指令XCHG (4) 换码指令 XLAT,(1) 数据传送指令MOV 格式:MOV dest,src 功能:将源操作数的内容传送给目标操作数,源操作数不变。即(des

15、t) (src)。 其中: src可以为:mem,seg,imm dest可以为:mem,seg MOV可以实现一个字节或一个字的传送,但要求dest与src数据类型相同。,注意: (1)段寄存器CS不能作为目标操作数,即不能给CS赋值; (2)源操作数与目标操作数不能同时为内存操作数。,例:以下指令均为合法的传送指令,括号中为目标操作数与源操作数的寻址方式。 1) MOV AL,5 ;(寄存器,立即数) 2) MOV AX,BX ;(寄存器,寄存器) 3) MOV DS,AX ;(段寄存器,寄存器) 4) MOV AX,DS ;(寄存器,段寄存器) 5) MOV ES:VAR,12 ;(存储

16、器,立即数) 6) MOV WORD PTR BX,12 ;(存储器,立即数) 其中:VAR为符号地址;WORD PTR指明存储器的属性是字属性。,(2) 堆栈操作指令 堆栈是计算机的一种数据结构,数据的存取原则是“先进后出”。好比货物堆放,先到的货物放在下面,后到的货物堆放在上面;取货物时,堆在上面的货物被先取走。 一般地,计算机系统中堆栈区建立在内存中,通过堆栈指针实现堆栈的管理。堆栈指针总是指向栈顶。堆栈指针的初值为栈底。把数据存入堆栈中,同时调整堆栈指针保持指向栈顶,这一操作称为入栈(或压入);把数据从堆栈中取出,同时调整堆栈指针保持指向栈顶,称为出栈(或弹出)。,1) 进栈指令PUS

17、H 格式: PUSH src src可以是:r16、seg、m16 功能:堆栈指针减2,并将寄存器、段寄存器或存储器中的一个字数据压入堆栈。 即: SP SP - 2 (SP+1,SP) (src) 执行过程可描述为:先减后压,2) 出栈指令POP 格式: POP dest dest可以是:r16(除CS外)、seg、m16 功能:将栈顶元素弹出送至某一寄存器、段寄存器(除CS外)或存储器,堆栈指针加2。 即: (dest) (SP+1,SP) SP SP + 2 执行过程可描述为:先弹后加,例:MOV AX,6688H PUSH AX POP BX 若执行入栈指令前,堆栈段寄存器SS = 2

18、100H,堆栈指针SP=0010H;执行入栈指令后,字单元SS:000EH的内容(SS:000EH)=6688H;堆栈指针SP=000EH,指向新的栈顶。 执行过程如图所示:,【例】P50,设(SS)=2011H,(SP)=0020H,依次执行下列汇编指令后,分析堆栈中的数据和寄存器AX、BX、SP的变化情况。 MOV AX,0103H MOV BX,1228H PUSH AX PUSH BX POP AX,(3) 数据交换指令 XCHG 格式:XCHG dest,src dest可为reg、mem;src可为reg、mem。但不能同时为mem。 功能:将源操作数与目标操作数互换。即(dest

19、)(src) 【例】利用XCHG,实现两个内存单元NUM1和NUM2的内容互换。 MOV AX,NUM1 XCHG AX,NUM2 MOV NUM1,AX 由于XCHG指令不允许同时对两个存储单元进行操作,因而必须借助于一个通用寄存器。先把一个存储单元中的数据传送到通用寄存器;再将通用寄存器中的内容与另一个存储单元内容进行交换;把通用寄存器中的内容回传给第一个存储单元。,【例】用三种方法实现将AX,BX两个寄存器内容互换。,方法一: MOV CX,AX MOV AX,BX MOV BX,CX,方法二: PUSH AX PUSH BX POP AX POP BX,方法三: XCHG AX,BX,

20、(4) 换码指令 XLAT 格式:XLAT 源操作数、目标操作数均隐含。 功能:把数据段中偏移地址为BX+AL的内存单元的内容传送到AL中,即:AL(BX + AL)。 【例】设BX=0100H,AL=03H,以DS:BX为首址的一段内存单元内容如图所示,指令XLAT执行后,AL=?,2 地址传送指令,(1) 取有效地址指令LEA (2) 地址指针装入DS指令LDS (3) 地址指针装入ES指令LES,(1) 取有效地址指令LEA 格式:LEA r16,mem 功能:取内存单元mem的有效地址,送到16位寄存器r16中,即:r16 EA(mem)。 【例】设 DS = 2100H,BX = 1

21、00H,SI = 10H, (DS:110H) = 1234H,指令 LEA BX,BX+SI 执行后,BX? BX = BX + SI = 110H (2) 地址指针装入DS指令LDS 格式:LDS r16,m32 功能:把内存中的32位源操作数中低16位送到指定寄存器r16中,高16位送到段寄存器DS中。即:r16 m32低16位; DS m32高16位。 (3) 地址指针装入ES指令LES 把上述指令中的DS换成ES,即成为LES指令,【例】从VAR开始的内存分布如图所示,执行指令LDS BX,VAR后,BX=?,DS=?,3 标志传送指令,(1) 取标志指令LAHF (2) 置标志指令

22、SAHF (3) 标志入栈指令PUSHF (4) 标志出栈指令POPF,(1) 取标志指令LAHF 格式:LAHF 该指令源操作数隐含为标志寄存器低8位,目标操作数隐含为AH。 功能:将标志寄存器的低8位送入AH寄存器。即AH (FLAGS)70 (2) 置标志指令SAHF 格式:SAHF 该指令源操作数隐含为AH,目标操作数隐含为标志寄存器。 功能:把寄存器AH内容送标志寄存器低8位,即(FLAG)07 AH (3) 标志入栈指令PUSHF 格式:PUSHF 该指令源操作数隐含为标志寄存器,目标操作数隐含为堆栈区。 功能:标志寄存器入栈。 SP SP 2 (SP + 1,SP) FLAG,(

23、4) 标志出栈POPF 格式:POPF 该指令源操作数隐含为堆栈区,目标操作数隐含为标志寄存器。 功能:数据出栈到标志寄存器。 FLAG (SP+1,SP) SP SP + 2 【例】利用LAHF、SAHF把标志位CF求反,其它位不变。 LAHF ;取标志寄存器的低8位 XOR AH,01H ;最低求反,其它位不变 SAHF ;送入标志寄存器的低8位,4 I/O指令IN、OUT,I/O指令用于CPU与输入、输出设备端口之间的数据传送。指令有两类:IN和OUT。IN用于CPU从外设读数据,OUT用于CPU向外设写数据。对外设的寻址方式有两种:直接寻址和间接寻址。,(1) 直接寻址 指令中直接给出

24、端口地址,相应的指令格式如下: 输入格式:IN AL/AX,port 输出格式:OUT port,AL/AX 说明: port为端口地址,取值范围为:0255(FFH); 操作数类型为字节时,选用AL寄存器,类型为字时,选用AX寄存器; 【例】从端口60H读字节,把它低4位清0后,再从60H送出。 IN AL,60H ;从60H读8位数 AND AL,0F0H ;低4位清0 OUT 60H,AL ;从60H送出,(2) 间接寻址 端口地址存于DX寄存器中。相应的指令格式如下: 数据为字节时: 数据为字时: 输入格式:IN AL,DX 输入格式: IN AX,DX 输出格式:OUT DX,AL

25、输出格式: OUT DX,AX 说明: 端口地址,取值范围为:065535(0FFFFH); 操作数类型为字节时,选用AL寄存器,类型为字时,选用AX寄存器; 【例】使用间接寻址方式实现:从端口60H读字节,把它低4位清0后,再从61H送出。 MOV DX,60H ;源端口地址送DX寄存器中 IN AL,DX ;从60H读8位数 AND AL,0F0H ;低4位清0 INC DX ;DX寄存器内容为目标端口地址 OUT DX,AL ;从61H送出数据,注意: (1) 对外设端口操作时,当端口地址在0255范围内,寻址方式可选用直接寻址,也可选用间接寻址;当端口地址大于255时,只能选用间接寻址

26、,并且地址寄存器只能用DX。 (2) 数据寄存器只能用AL(字节操作)或AX(字操作)。当使用AX时,对IN指令来说:是将port或DX所指向的端口数据读入AL,将port+1或DX+1所指向的端口数据读入AH;对OUT指令来说:是将AL寄存器内容送port或DX所指向的端口,将AH寄存器内容送port+1或DX+1所指向的端口。,总结: 数据传送指令除SAHF、POPF指令对标志位有影响外,其余指令对标志位无影响。 在汇编语言程序设计中,指令对标志位的影响通常成为程序控制的依据。在学习中,指令对标志位的影响也是学习的一个重点。,4.2.2 算术运算指令,1. 概述 2. 扩展指令 3. 加、

27、减指令 4. 乘、除指令 5. BCD数调整指令,1 概述,算术运算指令完成的操作可归为3类:一类是辅助运算指令(CBW,CBD);二类实现算术运算中的加(ADD,ADC)、减(SUB,SBB)、乘(MUL,IMUL)、除(DIV,IDIV)、加1(INC)、减1(DEC)、数据比较(CMP);三类实施BCD数算术运算结果调整(DAA,DAS,AAA,AAS,AAM,AAD)。 操作数分为4种类型:无符号数、有符号数、无符号压缩BCD数、无符号非压缩BCD数。压缩BCD数可以加、减,其余3类数据可进行加、减、乘、除四种运算,如表所示:,算术运算指令绝大部分对标志位产生影响,这些影响会成为编写汇

28、编语言程序正确与否的重要依据之一,在学习过程中要特别注意。具体影响请参见教材P63页。,2 扩展指令,扩展指令用于将字节扩展为字(CBW)或字扩展为双字(CWD),指令格式及功能如表所示:,【例】 (1) MOV AL,75H CBW 执行结果为:AX = 0075H (2) MOV AX,0A085H CBW 执行结果为:DX = 0FFFFH,AX = 0A085H,3 加、减指令,其中:dest 可以为reg,mem,src可以为reg、mem、imm,dest与src不能同时为内存操作数。,【例】设DX=4652H,执行指令ADD DX,7A08H后,DX=?,CF=?,SF=?,ZF

29、=?,OF=?,根据计算:DX=C05AH,结果不为0,ZF=0;运算结果没有进位,CF=0;运算结果的最高位为1,SF=1;加数、被加数均为正数,而结果为负数,产生溢出,OF=1。,【例】设AL=0FFH,执行指令INC AL后,AL=?,CF=?,SF=?,ZF=?,OF=? 根据计算:AL=00H,结果为0,ZF=1;运算结果的最高位为0,SF=0;0FFH为符号数,其真值为-1,加1后,结果为0,不溢出,OF=0。因INC指令不影响CF标志位,所以CF标志位不变。 【例】用编程实现将BX-AX组成的32位数与DX-CX组成的32位数相加,和送BX-AX。 ADD AX,CX ADC B

30、X,DX 分析:若不用ADC指令,只用ADD指令,程序就没有上面程序简洁,因为进行高16位相加时,必须考虑低16位相加时有没有进位,若有进位,高16位相加后,还要加1。,【例】设DL=78H,执行指令NEG DL后,DL=?,CF=?,SF=?,ZF=?,OF=? 分析:求补有两种方法,一是将0减去源操作数;二是将源操作数求反后再加1。执行NEG指令后,OF0。此外,计算机内部采用第一种方法,所以CF1。 运行结果:DL=88H,CF=1,SF=1,ZF=0,OF=0。 在加法指令(ADD,ADC)、减法指令(SUB、SBB)执行后,判断溢出标志位OF的方法是:同号数相加或异号数相减可能产生溢

31、出,异号数相加或同号数相减不溢出(OF=0)。如:两个正数相加,结果为负数;或两个负数相加,结果为正数,则OF=1。,【例】设求|X|,结果存入Y中,mov al,x test al,80h jz odd neg al odd:mov y,al,data segment xdb 78h ydb ? data ends,CMP dest,src指令通过执行dest-src减操作,对标志寄存器的状态位产生影响,以此可判别目标操作数与源操作数之间的大小关系。 由于无符号数与符号数表示规则不同(符号数的最高位为符号位,无符号数各位均为数字位),表示数的范围不同(长度为8的操作数,视为符号数,表示范围为

32、:-128+127,视为无符号数,表示范围为:0255),使得无符号数与符号数大小判定依据不同。 无符号数相减,可以通过有没有借位来判断,不存在溢出问题。无符号数A-B可能情况如下左表所示,从中,不难归纳出无符号数的大小判断依据,如下右表所示:,有符号数相减,不仅考虑正、负,并且可能存在溢出,所以与大小相关的标志位有SF、ZF与OF。符号数A-B可能情况如表所示:,符号数比较,不发生溢出(OF=1)时,如果SF=0,则AB,如果SF=1,则AB,如果SF=0,则AB。符号数大小判定依据归纳如表所示:,4 乘、除指令,src可以为:reg,mem,不允许为立即数。,(1) 乘法指令MUL、IMU

33、L 8086/8088可实施字节与字节乘、字与字乘,指令中给出乘数,被乘数隐含。乘数可以是寄存器或内存操作数,不能为立即数。 字节乘时,被乘数隐含为寄存器AL,乘积的高8位存于寄存器AH中,低8位存于寄存器AL中。字乘时,被乘数隐含为寄存器AX,乘积的高16位存于寄存器DX中,低16位存于寄存器AX中。 乘法指令仅影响标志位OF,CF,对其它标志位无定义。无符号数乘时,当积的高8位(字节乘)或积的高16位(字乘)为0,则 OF=CF=0;如果不为0,则OF=CF=1。符号数乘时,当积的高8位(字节乘)或积的高16位(字乘)是低字节(字节乘)或低字(字乘)的符号扩展时,OF=CF=0;否则,OF

34、=CF=1。,【例】64H 0A5H (1)无符号数乘,即100 165 = 16500D MOV AL,64H ;AL = 64H = 100D MOV BL,0A5H ;BL = 0A5H = 165D MUL BL ;AX = 4074H = 16500D,OF=CF=1 (2)符号数乘,即100 (-91) = -9100D MOV AL,64H ;AL = 64H = 100D MOV BL,0A5H ;BL = 0A5H = -91D IMUL BL ;AX = 0DC74H = -9100D,OF=CF=1,(2) 除法指令DIV,IDIV 8086/8088可实施除数为字节与除

35、数为字的两种除法。指令中给出除数,被除数隐含。除数可以是寄存器或内存操作数,不能为立即数。 除数为字节时,被除数必须为16位,隐含为寄存器AX,商存于寄存器AL中,余数存于寄存器AH中。除数为字时,被除数必须为32位,隐含为寄存器DX、AX,商存于寄存器AX中,余数存于寄存器DX中。 除非发生“溢出”,除法对所有标志位均无定义。所谓“溢出”,指除数为字节时,商大于FFH或除数为字时,商大于FFFFH。当除法发生溢出时,OF=1,并产生0型中断(溢出中断)。 符号数除法中,商的符号遵循除法法则,余数的符号与被除数一致。,【例】40003H 8000H (1)无符号数除,即:262147 3276

36、8 = 83 MOV DX,4 MOV AX,3 ;(DXAX) = 40003H = 262147D MOV CX,8000H ;CX = 8000H = 32768D DIV CX ;商AX = 8,余数DX = 3 (2)符号数除,即:262147 (-32768) = -83 MOV DX,4 MOV AX,3 ;(DXAX) = 40003H = 262147D MOV CX,8000H ;CX = 8000H = -32768D IDIV CX ;商AX = FFF8H = -8, ;余数DX = 3,5 BCD数调整指令,(1) 调整原理 8421BCD编码用4位二进制数表示一位

37、十进制数,4位二进制数表示范围是00001111,对应十进制数015,而一位十进制数表示范围是09,所以,当某十进制位运算值超过9或发生进位/借位时,运算结果会出错,需要调整。BCD调整指令,用于对BCD数进行加、减、乘、除运算时的调整,使结论正确,并且仍然是BCD的编码形式。,【例】非压缩BCD调整 (1) 8 + 7 = 15 0 0 0 0 1 0 0 0 8H + 0 0 0 0 0 1 1 1 7H 0 0 0 0 1 1 1 1 1FH,结果错, 11119,加6调整 + 0 0 0 0 0 1 1 0 0 0 0 1 0 1 0 1 15H 结果正确 (2) 9 + 8 = 17

38、 0 0 0 0 1 0 0 1 9H + 0 0 0 0 1 0 0 0 8H 0 0 0 1 0 0 0 1 11H,结果错, AF=1,需加6调整 + 0 0 0 0 0 1 1 0 0 0 0 1 0 1 1 1 17H 正确结果,【例】压缩BCD调整 (1) 18 7 25 0 0 0 1 1 0 0 0 18H + 0 0 0 0 0 1 1 1 7H 0 0 0 1 1 1 1 1 1FH,结果错, 11119,需加6调整 + 0 0 0 0 0 1 1 0 0 0 1 0 0 1 0 1 25H 正确结果 (2) 19 + 98 = 27 0 0 0 1 1 0 0 1 19H

39、 + 1 0 0 1 1 0 0 0 98H 1 0 1 1 0 0 0 1 B1H 结果错。AF=1,加6调整 + 0 0 0 0 0 1 1 0 1 0 1 1 0 1 1 1 B7H 结果错。高位10119,需加60H调整 + 0 1 1 0 0 0 0 0 1 0 0 0 1 0 1 1 1 117H 结果对。,总结: 在非压缩BCD数运算中,若和大于9或有辅助进位(AF=1)就需加6调整。同理,减法中,若差大于9或有辅助借位(AF=1),就需减6调整。 在压缩的BCD数加法运算时,若低4位和大于9或有辅助进位(AF=1)就需在低4位“加6调整”;若高4位和大于9或有进位(CF=1)就

40、需在高4位“加6调整”。同理,在BCD数减法运算时,若低4位差大于9或有辅助借位(AF=1)就需在低4位“减6调整”;若高4位差大于9或有借位(CF=1),就需在高4位“减6调整”。,(1) 调整指令,1) 压缩BCD数加法调整指令DAA,【例】39 + 17 = 56 MOV AL,39H ADD AL,17H ;AL=50H,AF=1,CF=0 DAA ;AL=56H,2) 压缩BCD数减法调整指令DAS,【例】37 - 19 = 18 MOV AL,37H SUB AL,19H ;AL=1EH,AF=1,CF=0 DAS ;AL=18H,AF=1,3) 加法的ASCII调整指令AAA,【

41、例】7+9=16 MOV AL,7 ;AL=37H ADD AL,9 ;AL=70H,AF=1,CF=0 AAA ;AL=06H,CF=AF=1,4) 减法的ASCII调整指令AAS,【例】17 - 9= 8 MOV AL,7H ;AL=07H MOV AH,1H ;AH=1H SUB AL,9H ;AL=0FEH,AF=1,CF=1 AAS ;AL=8H,CF=AF=1,AH=0,5) 乘法的ASCII调整指令AAM,【例】9 3 = 27 MOV AL,9H ;AL = 0000 1001B MOV BL,3H ;BL = 0000 0011B MUL BL ;AH=0,AL=1BH=27

42、D AAM ;AH=02H,AL=07H,5) 除法的ASCII调整指令AAD,【例】15 3 = 5 MOV AH,1 MOV AL,5 MOV BL,3 AAD ;AL=110+5=15D=0FH DIV BL ;AL=05H,AH=0,4.2.3 逻辑指令,1. 逻辑运算指令 2. 移位指令 3. 循环移位指令,1 逻辑运算指令,逻辑运算指令包括逻辑非(NOT)、逻辑与(AND)、逻辑测试(TEST)、逻辑 或(OR)和逻辑异或(XOR)指令。这些指令的操作数可以是8位、16位,运算按位进行。对操作数的要求与MOV指令相同。指令格式如表所示:,【例】将AL寄存器中第3位和第7位置1。 M

43、OV AL,0 OR AL,88H 【例】从端口61H读取一个字节,D1位求反后,从61H送出 IN AL,61H XOR AL,00000010B OUT 61H,AL 【例】用逻辑指令将寄存器AX清零 XOR AX,AX,2 移位指令,移位指令包括:逻辑左移SHL、逻辑右移SHR、算术左移SAL、算术右移SAR。指令格式及功能如表所示:,这组指令除了可以实现基本的移位操作外,还可以用于实现数倍增(左移)或倍减(右移),使用这种方法比直接使用乘、除法效率要高得多。用逻辑移位指令实现无符号数的乘、除,算术移位指令实现符号数的乘、除。只要不超出数的表示范围,SHL或SAL执行后,数为原数的2CN

44、T,SHR或SAR执行后,数为原数的1/2CNT。 【例】设无符号数 X 在寄存器AL中,用移位指令实现X*10的运算 MOV AH,0 SAL AX,1 ;计算2X MOV BX,AX MOV CL,2 SAL AX,CL ;计算8X ADD AX,BX ;计算2X+8X = 10X,3 循环移位指令,循环移位指令包括以下4条:不带进位的循环左移(ROL)、不带进位的循环右移(ROR)、带进位的循环左移(RCL)、带进位的循环右移(RCR)。指令格式及功能如表所示:,4.2.4 串操作指令,所谓“串” 是指一组数据,所以串操作指令的操作对象不是一个字节或一个字,而是内存中地址连续的一组字节或

45、一组字。缺省情况下,原串存于数据段中,目标串存于附加段中。在每一次基本操作后,能够自动修改源地址及目标地址为下一次操作做好准备。串操作指令前可以加上重复前缀,此时,基本操作在满足条件的情况下得到重复,直至完成预设次数。,1 串操作指令,串操作指令共有5条,串传送指令MOVS、串装入指令LODS、串送存指令STOS、串比较指令CMPS、串扫描指令SCAS。具体格式及功能如表所示:,2 指令前缀,串操作指令的基本操作可以用于一个数据被执行一次,也可以用于一组数据重复执行,因此在指令中需要指明该指令的基本操作是否被重复、重复的条件是什么及重复的次数是多少。串操作的指令前缀用于说明前两个问题,重复次数

46、隐含在寄存器CX中。前缀有3种:无条件重复REP、相等重复REPE或REPZ、不相等重复REPNE或REPNZ。,3 加前缀的串操作指令,(1)与REP相配合的MOVS、STOS 重复串传送 格式: REP MOVS dest,src 或 REP MOVSB 或 REP MOVSW 操作: 若CX = 0,则结束该指令,执行后续指令;否则, CX CX 1 (ES:DI) (DS:SI) SI SI + 1 / 2 ,DI DI + 1 / 2 重复。 说明: MOVSB时,地址增/减量为1;MOVSW时,地址增/减量为2。,【例】把自AREA1开始的100个字传送到AREA2开始的区域中。

47、解:源、目标数据区,可能无重叠,也可能有重叠,如图所示:,(a) 源、目标区域无重叠,传送方向,地址增或地址减均可,以地址增为例。 MOV AX,SEG AREA1 MOV DS,AX ;源数据区段地址送段寄存器DS MOV AX,SEG AREA2 MOV ES,AX ;目标数据区段地址送段寄存器ES LEA SI,AREA1 ;源区首字的偏移地址送寄存器SI LEA DI,AREA2 ;目标区首字的偏移地址送寄存器DI MOV CX,100 ;串长度送寄存器CX CLD ;DF = 0,地址增 REP MOVSW ;串传送,(b) 源、目标区域有重叠,只能选择地址减 MOV CX,200

48、;串长度送寄存器CX MOV AX,SEG AREA1 MOV DS,AX ;源数据区段地址送段寄存器DS MOV AX,SEG AREA2 MOV ES,AX ;目标数据区段地址送段寄存器ES LEA SI,AREA1 ADD SI,CX DEC SI ;源数据区末字的偏移地址送寄存器SI LEA DI,AREA2 ADD DI,CX DEC DI ;目标数据区末字的偏移地址送寄存器DI STD ;DF = 1,地址减 REP MOVSB ;串传送, 重复串送存 格式:REP STOS dest 或 REP STOSB 或 REP STOSW 操作: 若CX = 0,则结束该指令,执行后续指

49、令;否则, CX CX 1 (ES:DI) AL DI DI + 1 / 2 重复。 重复串送存,用于在一段地址连续的内存单元中置相同数。,【例】在内存DS:2100HDS:2110H中,存入符号$ MOV AL,$ MOV BX,DS MOV ES,BX ;目标段段地址送段寄存器ES MOV DI,2100H ;目标段首字节偏移地址送寄存器DI MOV CX,10H ;串长送寄存器CX CLD ;设置方向增 REP STOSB ;重复串送存,(2) 与REPE或REPZ联合使用的CMPS 格式: REPE/REPZ CMPS dest,src 或 REPE/REPZ CMPSB 或 REPE

50、/REPZ CMPSW 操作: 若CX = 0或ZF=0,则结束该指令,执行后续指令;否则, CX CX 1 (DS:SI) (ES:DI),影响标志位 SI SI + 1 / 2 ,DI DI + 1 / 2 重复第。 该指令把源串与目标串的数据逐个比较,相等继续比下去。退出该指令时,有两种情况:(1) 比较完毕退出,此时CX=0;(2) 不相等退出,此时ZF=0,表示两串不相等。所以,该指令常用于判断两串是否相等。方法是检测退出后标志位ZF:ZF=1,两串相等;ZF=0,两串不相等。从以上分析可知,不能以是否比较完毕来判断两串是否相等。,【例】比较串STR1、STR2,若相等,给寄存器AX

51、置全1,否则AX中为不相等处地址。 ;数据定义 STR1 DB ABCDEFGHIJK ;串1,作为源串 STR2 DB ABCDFGKJ ;串2,作为目标串 N DW 20 ;串长 ;功能代码 MOV AX,SEG STR1 MOV DS,AX ;源串段地址送DS MOV AX,SEG STR2 MOV ES,AX ;目标串段地址送ES LEA SI,STR1 ;源串偏移地址送SI LEA DI,STR2 ;目标串偏移地址送DI MOV CX,N ;重复次数送CX CLD ;地址增 REPE CMPSB ;相等继续比较,不相等退出 JZ EQUAL ;退出时,若ZF = 1,表示两串相等 D

52、EC SI ;不相等,指针退1,指向不相等处 MOV AX,SI ;保存不相等处地址 JMP FINISH EQUAL: MOV AX,0FFH ;相等,AX为0FFH FINISH:HLT,(3) 与REPNE或REPNZ联合使用的SCAS 格式: REPNE/REPNZ SCAS dest 或 REPNE/REPNZ SCASB 或 REPNE/REPNZ SCASW 操作: 若CX = 0或ZF=1,则结束该指令,执行后续指令;否则, CX CX 1 AL/AX ( ES:DI ),影响标志位 DI DI + 1 / 2 重复第。 该指令把目标串的数据逐个与AL/AX中数据比较,不相等继

53、续比下去。退出该指令时,有两种情况:(1) 碰到与AL/AX相等的数据,此时,ZF=1;(2)目标串中不存在与AL/AX相等的数据,此时,CX=0。本指令适用于在串中寻找某特定字节或字,在该字节或字第一次出现时,停止指令操作,但数据指针DI指在该数据的后一个数据处。,【例】在串STR中寻找字符串AB,若有,把其出现的位置存于寄存器BX中,否则,BX置0FFH。 ;数据定义 STR DW ABCDEFGHIJK N EQU ($-STR)/2 ;串长 KEY DW AB ;功能代码 CLD ;地址增 MOV AX,SEG STR ;目标串段地址送段寄存器ES MOV ES,AX LEA DI,S

54、TR ;目标串首字的偏移地址送寄存器DI MOV AX,KEY ;被寻找字送寄存器AX MOV CX,N ;串长送寄存器CX REPNE SCASB ;不相等继续寻找,一旦相等退出 JNZ NEQUAL ;退出时,若ZF = 0,表示未找到 SUB DI,2 ;相等,数据指针退2,指向相等处 MOV BX,DI ;保存关键字出现地址 JMP FINISH NEQUAL: MOV BX,0FFH ;末找到,BX为0FFH FINISH: ,4.2.5 控制转移指令,控制转移指令用来改变程序的执行顺序,执行转移就是将目的地址传送给代码段寄存器CS与指令指针寄存器IP。如果跳转目的地与被转移点在同一

55、代码段,称为“段内转移”,此时,只需指明目标地址的有效地址(16位)。如果跳转目的地与被转移点不在同一代码段,称为“段间转移”,此时,需知道目标地址的段地址(16位)及有效地址(16位)。 控制转移指令的寻址方式分为“直接寻址”、“间接寻址”两种。如果指令中直接给出目标地址,如地址标号或立即数(偏移量,目标与源之间的偏移距离),称为“直接寻址”;如果指令中,给出目标地址存放地的地址,如寄存器或内存地址,称为“间接寻址”。 控制转移指令包括:转移指令、循环控制指令、过程调用指令和中断指令等4类。,1 转移指令,转移指令将正在被执行的指令集的执行点从一处转到另一处。源地址与目标地址的距离称为跳转“

56、偏移量”,偏移量是符号数。当用一个字节表示偏移量时,即源地址与目标地址之距在+127-128之间,称为“短(short)转移”,当用一个字表示偏移量时,即源地址与目标地址之距在+32767-32768之间,称为“近(near)转移”。 转移指令又可分为两类:无条件转移指令与条件转移指令。,无条件转移指令JMP 格式:JMP dest ,dest可以是标号、立即数、寄存器、内存操作数。,(2) 条件转移指令 (只能用于段内直接寻址方式) 格式:Jcc short-label ,cc代表跳转条件,该指令只能实现段内短转移。,续表,【例】比较两个字属性的符号数X,Y的大小,如果XY,AL为1,如果X

57、=Y,AL为0,如果X Y,AL=1 JMP DONE LE:JL L MOV AL,00H ;X = Y,AL=00H JMP DOWN L:MOV AL,0FFH ;X Y,AL=0FFH DONE:HLT,2 循环控制指令,循环指程序段在一定条件下重复执行。循环指令提供了程序段循环的控制及手段。这些指令都用CX寄存器作为循环次数计算器,表示某程序段最大循环次数,且循环体每执行一次,CX被减去1。8086/8088CPU规定被循环的程序段必须在同一段内,且长度不能大于256字节。 循环控制指令有3条:循环指令LOOP、相等循环指令LOOPE/LOOPZ、不相等循环指令LOOPNE/LOOP

58、NZ,其格式及功能如表所示:,【例】有一首地址为Array的长度为M字数组,试编写实现下列功能的代码:统计出数组中0元素的个数,并存入变量total中。 MOV CX,M ;数组长度存入循环计数器CX MOV total,0 ;计数变量初始值为0 MOV SI,0 ;采用寄存器相对寻址,初始偏移量送寄存器SI AGAIN:MOV AX,ArraySI ;取数 CMP AX,0 ;与0比较 JNZ NEXT ;不为0,取下一个数 INC total ;为0,计数器加1 NEXT:ADD SI,2 ;调整地址,指向下个数 LOOP AGAIN ;进入下一轮循环 显然,LOOP AGAIN指令等效于下列语句: DEC CX JNZ AGAIN 但是,LOOP指令

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论