版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、第一讲第三章指令系统 - 寻址方式回顾 : 8086/8088 的内部结构和寄存器,地址分段的概念,8086/8088 的工作过程。重点和纲要: 指令系统 - 寻址方式。有关寻址的概念;6 种基本的寻址方式及有效地址的计算。教学方法、实施步骤时间分配教学手段回顾5”× 2板书讲授40” ×2计算机提问3” ×2投影仪小结2” ×2多媒体课件等讲授内容:3.1 8086/8088寻址方式首先,简单讲述一下指令的一般格式:操作码操作数操作数计算机中的指令由操作码字段和操作数字段组成。操作码:指计算机所要执行的操作,或称为指出操作类型,是一种助记符。操作数:指
2、在指令执行操作的过程中所需要的操作数。 该字段除可以是操作数本身外,也可以是操作数地址或是地址的一部分,还可以是指向操作数地址的指针或其它有关操作数的信息。寻址方式就是指令中用于说明操作数所在地址的方法,或者说是寻找操作数有效地址的方法。 80868088 的基本寻址方式有六种。1立即寻址所提供的操作数直接包含在指令中。 它紧跟在操作码的后面,与操作码一起放在代码段区域中。如图所示。例如: MOV AX,3000H1立即数可以是 8 位的,也可以是 16 位的。若是 16 位的,则存储时低位在前,高位在后。立即寻址主要用来给寄存器或存储器赋初值。2直接寻址操作数地址的16 位偏移量直接包含在指
3、令中。它与操作码起存放在代码段区域,操作数一般在数据段区域中,它的地址为数据段寄存器DS加上这 16 位地址偏移量。如图2-2 所示。例如:MOV AX,DS: 2000H ;图 22(对 DS来讲可以省略成MOV AX ,2000H , 系统默认为数据段)这种寻址方法是以数据段的地址为基础,可在多达64KB 的范围内寻找操作数。8086/8088 中允许段超越,即还允许操作数在以代码段、堆栈段或附加段为基准的区域中。此时只要在指令中指明是段超越的,则16 位地址偏移量可以与CS或 SS或 ES相加,作为操作数的地址。MOVAX,2000H;数据段MOVBX,ES: 3000H;段超越,操作数
4、在附加段即绝对地址( ES) 163000H3寄存器寻址操作数包含在 CPU的内部寄存器中,如寄存器AX、BX、CX、DX等。例如: MOV DS,AXMOV AL,BH4寄存器间接寻址操作数是在存储器中,但是,操作数地址的16 位偏移量包含在以下四个寄2存器 SI 、 DI、BP、BX之一中。可以分成两种情况:(1)以 SI 、DI 、BX 间接寻址,则通常操作数在现行数据段区域中,即数据段寄存器(DS) 16加上 SI、DI、BX中的 16 位偏移量,为操作数的地址,例如: MOV AX , SI操作数地址是:(DS) *16+( SI )(2)以寄存器 BP间接寻址,则操作数在堆栈段区域
5、中。 即堆栈段寄存器 (SS)16 与 BP的内容相加作为操作数的地址,例如: MOV AX,BP操作数地址是:( SS)*16+(BP)若在指令中规定是段超越的,则 BP的内容也可以与其它的段寄存器相加,形成操作数地址。例如:MOV AX , DS:BP操作数地址是:(DS)*16+(BP)5变址寻址由指定的寄存器内容, 加上指令中给出的8 位或 16 位偏移量(当然要由一个段寄存器作为地址基准)作为操作数的偏移地址。(操作数在存贮器中)可以作为寄存器变址寻址的四个寄存器是SI 、DI、 BX、BP。若用 SI 、DI 和 BX作为变址,则与数据段寄存器相加,形成操作数的地址即默认在数据段;
6、若用 BP变址,则与堆栈段寄存器相加,形成操作数的地址即默认在堆栈段例如: MOV AX ,COUNTSI;操作数地址是:(DS)*16+(SI )+COUNT但是,只要在指令中指定是段超越的, 则可以用别的段寄存器作为地址基准。6基址加变址寻址把 BX和 BP 看成是基址寄存器,把SI 、 DI 看着是变址寄存器,把一个基址寄存器(BX或 BP)的内容加上一个变址寄存器( SI 或 DI )的内容,再加上指令中指定的 8 位或 16 位偏移量(当然要以一个段寄存器作为地址基准)作为操作3数的偏移地址,如图所示。操作数在存贮器中,其偏移地址由(基址寄存器)(变址寄存器)相对偏移量形成基址寄存器
7、 BX:数据段、 BP:堆栈段;变址寄存器 SI 、DI 。例如: MOVAX ,BXSI或 MOVAX,BX+SI也可放置一个相对偏移量,如COUNT、MASK等等,用于表示相对寻址。MOVAX , MASKBXSIMOVBH, COUNTDIBP;MOVBH, COUNTBP+DI若用 BX作为基地址,则操作数在数据段区域若用 BP作为基地址,则操作数在堆栈段区域但若在指令中规定段是超越的,则可用其它段寄存器作为地址基准。P28表 2-1段寄存器使用的基本约定访问存储器类型默认段寄存器可指定段寄存器段内偏移地址来源取指令码CS无IP堆栈操作SS无SP串操作源地址DSCS、 ES、 SSSI
8、串操作目的地址ES无DIBP用作基址寄存器SSCS、 DS、 ES根据寻址方式求得有效地址一般数据存取DSCS、 ES、 SS根据寻址方式求得有效地址习题与思考:1假定 DS=2000H, ES=2100H, SS=1500H, SI=00A0H, BX=0100H, BP=0010H,数据变量 VAL 的偏移地址为 0050H,请指出下列指令源操作数是什么寻址方式?其物理地址是多少?( 1) MOVAX , 0ABH( 2) MOVAX, 100H( 3) MOVAX,VAL( 4)MOVBX, SI( 5) MOVAL,VALBX( 6)MOVCL, BXSI( 7) MOVVALSI ,
9、 BX( 8) MOVBPSI, 1002已知 SS=0FFA0H, SP=00B0H,先执行两条把 8057H 和 0F79H 分别进栈的 PUSH指令,再执行一条 POP指令,试画出堆栈区和 SP内容变化的过程示意图。 (标出存储单元的地址)4第二讲3.2指令系统 - 数据传输、算术运算回顾: 8086/8088 的内部结构和寄存器,8086/8088 的工作过程。8086/8088 的寻址方式及操作数地址的计算。重点和纲要: 要求学生了解指令的功能,掌握数据传送类,算术运算类指令的使用方法。(掌握指令内涵,会用)教学方法、实施步骤时间分配教学手段回顾5”× 2板书讲授40” &
10、#215;2计算机提问3” ×2投影仪小结2” ×2多媒体课件等讲授内容 :3.2 8086/8088指令系统8086 8088 的指令系统可以分为以下六个功能组。1数据传送 (Data Transter)2算术运算 (Arithmetic)3逻辑运算 (Logic)4串操作 (String menipulation)5程序控制 (Program Control)6处理器控制 (Processor Control)一、数据传送指令主要介绍 MOV,XCHG、堆栈和地址传送指令。51数据传送 MOV指令一般格式: MOV OPRD1, OPRD2MOV是操作码, OPRD1和
11、 OPRD2分别是目的操作数和源操作数。功能:完成数据传送具体来说,一条数据传送指令能实现:CPU内部寄存器之间数据的任意传送( 除了代码段寄存器CS 和指令指针IP 以外 ) 。MOV AL, BL;字节传送 MOV CX, BX;字传送MOV DS, BX立即数传送至CPU内部的通用寄存器组 ( 即 AX、 BX、CX、DX、BP、SP、SI 、DI) ,MOV CL, 4MOV AX, 03FFHMOV SI, 057BHCPU内部寄存器 ( 除了 CS和 IP 以外 ) 与存储器 ( 所有寻址方式 ) 之间的数据传送。MOV AL, BUFFERMOV AX, SIMOV DI ,CX
12、MOV SI, BLOCKBPMOV DS, DATASI+BXMOV DESTBP+DI,ES能实现用立即数给存储单元赋值例如: MOV 2000H, 25HMOV SI , 35H对于 MOV指令应注意几个问题:存储器传送指令中,不允许对CS和 IP 进行操作;两个操作数中,除立即寻址之外必须有一个为寄存器寻址方式,即两个存储器操作数之间不允许直接进行信息传送;如我们需要把地址 ( 即段内的地址偏移量 ) 为 AREAl的存储单元的内容,传送至同一段内的地址为 AREA2的存储单元中去, MOV指令不能直接完成这样的传送,但我们可以用 CPU内部寄存器为桥梁来完成这样的传送:MOV AL,
13、 AREAl6MOV AREA2,AL两个段寄存器之间不能直接传送信息,也不允许用立即寻址方式为段寄存器赋初值;如: MOV AX, 0; MOV DS, AX目的操作数,不能用立即寻址方式。2堆栈指令(简述堆栈的概念及存取特点,如先进后出)包括入栈( PUSH)和出栈( POP)指令两类。仅能进行字运算。 (操作数不能是立即数)入栈指令 PUSH一般格式: PUSH OPRD源操作数可以是 CPU内部的 16 位通用寄存器、段寄存器( CS除外)和内存操作数(所有寻址方式) 。入栈操作对象必须是 16 位数。功能:将数据压入堆栈执行步骤为: SP=SP-2; SP= 操作数低 8 位; SP
14、+1= 操作数高 8 位例如: PUSH BX执 行过程 为: SP=SP-1, SP=BH; SP=SP-1,SP=BL,如图 2-8 所示。出栈指令 POP一般格式: POP OPRD功能:将数据弹出堆栈对指令执行的要求同入栈指令。例如: POPAX图 2-8POPBXPOPDS3交换指令XCHG一般格式: XCHG OPRD1,OPRD2功能:完成数据交换这是条交换指令,把一个字节或一个字的源操作数与目的操作数相交换。交换能在通用寄存器与累加器之间、通用寄存器之间、通用寄存器与存储器之间7进行。但段寄存器和立即数不能作为一个操作数,不能在累加器之间进行。例如: XCHG AL,CLXCH
15、G AX,DIXCHG BX,SIXCHG AX,BUFFERXCHG DATASI,DH4累加器专用传送指令有三种,输入、输出和查表指令。前两种又称为输入输出指令。IN指令一般格式: INAL ,n; BALnINAX ,n; W AX n+1nINAL ,DX; B AL DXINAX ,DX ; W AX DX+1DX功能:从 I/O 端口输入数据至AL 或 AX。输入指令允许把一个字节或一个字由一个输入端口传送到AL或 AX中。若端口地址超过 255 时,则必须用 DX保存端口地址,这样用DX作端口寻址最多可寻找 64K个端口。 OUT 指令一般格式: OUT n,AL;BALnOUT
16、 n,AX;WAXn+1nOUT DX,AL ; BALDXOUT DX,AX ; WAX DX+1DX功能:将 AL或 AX的内容输出至 I/O 端口。该指令将 AL或 AX中的内容传送到一个输出端口。端口寻址 方式与 IN 指令相同。 XLAT 指令一般格式: XLAT;AL=(DX)× 16( BX)+( AL)功能:完成一个字节的查表转换。要求:寄存器 AL 的内容作为一个256 字节的表的下标。 表的基地址在 BX中,转换后的结果存放在AL中.TABLE:例如: MOVBX, OFFSET TABLE8MOVAL, 8INAL ,1第 9 个字符AAHXLAT ;查表OUT
17、1 ,AL;(AL) AAH表长度 256本指令可用在数制转换、函数表查表、代码转换等场合。5地址传送指令(有三条地址传送指令) LEA (Load Effective Address)一般格式: LEA OPRD1,OPRD2功能:把源操作数OPRD2的地址偏移量传送至目的操作数OPRD1。要求:源操作数必须是一个内存操作数,目的操作数必须是一个16 位的通用寄存器。这条指令通常用来建立串操作指令所须的寄存器指针。例: LEA BX, BUFR;把变量 BUFR的地址偏移量部分送到BX LDS (Load pointer into DS)一般格式: LDS OPRD1,OPRD2功能:完成一
18、个地址指针的传送。 地址指针包括段地址部分和偏移量部分。指令将段地址送入DS,偏移量部分送入一个16 位的指针寄存器或变址寄存器。要求:源操作数是一个内存操作数,目的操作数是一个通用寄存器 / 变址寄存器。例如: LDSSI ,BX;将把 BX所指的 32 位地址指针的段地址部分送入DS,偏移量部分送入SI 。图 2-9 LDS 指令示意如图 2-9 所示。 LES (Load pointer into ES)一般格式: LES OPRD1,OPRD2这条指令除将地址指针的段地址部分送入ES 外,与 LDS类似。例如: LESDI, BX+COUNT6标志寄存器传送(有四条标志传送指令)9 L
19、AHF ( LOAD AH WITH FLAG)将标志寄存器中的SF、ZF、AF、PF和 CF(即低 8 位)传送至 AH寄存器的指定位,空位没有定义。 SAHF ( STORE AH WITH FLAG)将寄存器 AH的指定位,送至标志寄存器的 SF、ZF、AF、PF和 CF位(即低 8 位)。根据 AH的内容,影响上述标志位,对 OF、DF和 IF 无影响。 PUSHF (PUSH FLAG)将标志寄存器压入堆栈顶部,同时修改堆栈指针,不影响标志位。 POPF ( POP FLAG)堆栈顶部的一个字,传送到标志寄存器,同时修改堆栈指针,影响标志位。二、算术运算指令8086 8088 提供加
20、、减、乘、除四种基本算术操作。这些操作都可用于字节或字的运算,也可以用于带符号数与无符号数的运算。带符号数用补码表示。同时80868088 也提供了各种校正操作,故可以进行十进制算术运算。参与加、减运算的操作数可如上图所示。1加法指令 (Addition)一般形式: ADD OPRD1,OPRD2功能: OPRD1OPRD1+OPRD2完成两个操作数相加,结果送至目的操作数OPRD1。目的操作数可以是累加器,任一通用寄存器以及存储器操作数。例如:ADDAL, 30;累加器与立即数相加ADDBX, 3000H ;通用寄存器与存储单元内容相加ADDDI, CX;通用寄存器之间ADDDX, DATA
21、BX+SI;通用寄存器与存储单元内容相加ADDBETASI , DX;存储器操作数与寄存器相加10这些指令对标志位CF、DF、 PF、SF、ZF 和 AF有影响。一般形式: ADC OPRD1, OPRD2;带进位的加法功能: OPRD1OPRD1+OPRD2 +CF这条指令与上条指令类似,只是在两个操作数相加时,要把进位标志 CF 的现行值加上去,结果送至目的操作数。ADC指令主要用于多字节运算中。 若有两个四字节的数, 已分别放在自 FIRST 和 SECOND开始的存储区中,每个数占四个存储单元。存放时,最低字节在地址最低处,则可用以下程序段实现相加。MOV AX, FIRSTADD A
22、X, SECOND;进行字运算MOV THIRD, AXMOV AX, FIRST+2ADC AX, SECOND+2MOV THIRD+2,AX这条指令对标志位的影响与ADD相同。一般形式: INC OPRD;功能: OPRD OPRD+1完成对指定的操作数OPRD加 1,然后返回此操作数。 此指令主要用于在循环程序中修改地址指针和循环次数等。这条指令执行的结果影响标志位AF、OF、 PF、SF 和 ZF,而对进位标志没有影响。如: INC ALINC BX2减法指令 (Subtraction)一般形式: SUB OPRD1,OPRD2 ;功能: OPRD1OPRD1-OPRD2完成两个操作
23、数相减,也即从OPRD1中减去 OPRD2,结果放在 OPRD1中。例如:SUBCX,BXSUB BP,CL一般形式: SBB OPRD1, OPRD2;功能: OPRD1OPRD1-OPRD2-CF这条指令与SUB类似,只是在两个操作数相减时,还要减去借位标志CF 的11现行值本指令对标志位AF、CF、OF、 PF、SF和 ZF都有影响。同 ADC指令一样,本指令主要用于多字节操作数相减。一般形式: DEC OPRD ;功能: OPRD OPRD-1-CF对指令的操作数减1,然后送回此操作数,在相减时,把操作数作为一个无符号二进制数来对待。指令执行的结果,影响标志 AF、OF、 PF、SF和
24、 ZF但对 CF标志不影响 ( 即保持此指令以前的值 ) 。例如:DEC SIDECCL一般形式: NEG OPRD功能:(NEGDate)取补对操作数取补,即用零减去操作数,再把结果送回操作数。例如: NEGALNEGMULRE(AL 00111100)则取补后为 11000100即 0000 00000011 11001100 0100若在字节操作时对 -128 ,或在字操作时对 -32768 取补,则操作数没变化,但标志 OF置位。此指令影响标志AF、CF、 OF、PF、 SF 和 ZF。此指令的结果一般总是使标志CF=1。除非在操作数为零时,才使CF=0。一般形式: CMP OPRD1
25、,OPRD2;功能: OPRD1-OPRD2比较指令完成两个操作数相减, 使结果反映在标志位上, 但并不送回结果 ( 即不带回送的减法 ) 。例如:CMPAL ,100CMPDX,DICMPCX,COUHTBPCMPCOUNTSI,AX比较指令主要用于比较两个数之间的关系。在比较指令之后,根据ZF 标志即可判断两者是否相等。相等的比较:若两者相等,相减以后结果为零,ZF 标志为 1,否则为 0。12若两者不相等,则可在比较指令之后利用其它标志位的状态来确定两者的大小。大小的比较:如果是两个无符号数(如CMP AX,BX)进行比较,则可以根据CF标志的状态判断两数大小。若结果没有产生借位(CF=
26、0),显然 AXBX;若产生了借位(即CF 1),则 AX BX。习题与思考:1设有关寄存器及存储单元的内容如下:DS=2000H,BX=0100H,AX=1200H,SI=0002H,20100H=12H , 20101H=34H ,20102H=56H , 20103=78H , 21200=2AH , 21201H=4CH , 21202H=0B7H , 21203H=65H 。试说明下列各条指令单独执行后相关寄存器或存储单元的内容。( 1)MOVAX, 1800H( 2) MOVAX, BX( 3)MOVBX, 1200H( 4) MOVDX, 1100BX( 5)MOVBXSI,AL
27、(6) MOVAX, 1100BXSI2写出实现下列计算的指令序列。(假定 X、 Y、 Z、 W、 R 都为字变量)( 1)Z=W+( Z+X)( 2) Z=W-( X+6) - ( R+9)3若在数据段中从字节变量 TABLE相应的单元开始存放了 015 的平方值,试写出包含有 XLAT 指令的指令序列查找 N( 015)中的某个数的平方。 ( 设 N 的值存放在 CL中 )第三讲3.3指令系统 - 算术运算、逻辑运算、控制转移回顾: 8086/8088 的内部结构和寄存器,8086/8088 的工作过程。8086/8088 的寻址方式及操作数地址的计算。重点和纲要: 要求学生了解指令的功能
28、,掌握算术运算类、逻辑运算和移位指令的功能和应用。 (掌握指令内涵,会用)13教学方法、实施步骤时间分配教学手段回顾5”× 2板书讲授40” ×2计算机提问3” ×2投影仪小结2” ×2多媒体课件等讲述内容:3乘法指令(分为无符号乘法指令和带符号乘法指令两类)(1) 无符号乘法指令 MUL一般格式:MUL OPRD完成字节与字节相乘、字与字相乘,且默认的操作数放在AL 或 AX 中,而源操作数由指令给出。 8 位数相乘,结果为 16 位数,放在 AX中; 16 位数相乘结果为 32 位数,高 16 位放在 DX,低 16 位放在 AX中。注意:源操作数不
29、能为立即数 。例如:MOV AL,FIRST;MUL SECOND ;结果为 AX=FIRST*SECONDMOVAX, THIRD;MULAX;结果 DX: AX=THIRD*THIRDMOVAL, 30HCBW; 字扩展 AX=30HMOVBX, 2000HMULBX;(2) 带符号数乘法指令 IMUL一般格式: IMULOPRD;OPRD 为源操作数这是一条带符号数的乘法指令,同MUL一样可以进行字节与字节、字和字的乘法运算。结果放在AX或 DX,AX中。当结果的高半部分不是结果的低半部分的符号扩展时,标志位CF和 OF将置位。4除法指令(1) 无符号数除法指令 DIV一般格式: DIV
30、 OPRD(2) 带符号数除法 IDIV14一般格式: IDIV OPRD该指令执行过程同DIV 指令,但 IDIV 指令认为操作数的最高位为符号位,除法运算的结果商的最高位也为符号位。在除法指令中,在字节运算时被除数在AX中;运算结果商在AL中,余数在AH中。字运算时被除数为DX: AX构成的 32 位数,运算结果商在AX中,余数在DX中。例如: AX=2000H,DX=200H,BX=1000H,则 DIV BX执行后, AX=2002H,DX=0000。除法运算中,源操作数可为除立即寻址方式之外的任何一种寻址方式,且指令执行对所有的标志位都无定义。由于除法指令中的字节运算要求被除数为16
31、 位数,而字运算要求被除数是32 位数,在 8086/8088 系统中往往需要用符号扩展的方法取得被除数所要的格式,因此指令系统中包括两条符号扩展指令。(3) 字节扩展指令 CBW一般格式: CBW该指令执行时将AL 寄存器的最高位扩展到AH,即若 D7=0,则 AH=0;否则AH=0FFH。(4) 字扩展指令 CWD一般格式: CWD该指令执行时将AX寄存器的最高位扩展到DX,即若 D15=0,则 DX=0;否则DX=0FFFFH。CBW、CWD指令不影响标志位。5十进制调整指令计算机中的算术运算,都是针对二进制数的运算,而人们在日常生活中习惯使用十进制。为此在8086/8088 系统中,针
32、对十进制算术运算有一类十进制调整指令。在计算机中人们用BCD码表示十进制数,对 BCD码计算机中有两种表示方法:一类为压缩 BCD码,即规定每个字节表示两位BCD数;另一类称为非压缩BCD码,即用一个字节表示一位BCD数,在这字节的高四位用0 填充。例如,十进制数 25D,表示为压缩 BCD数时为: 25H;表示为非压缩BCD数时为: 0205H,用两字节表示。相关的 BCD转换指令见表 2-2 。15例如:ADDAL , BLDAA若执行前: AL=28H, BL=68H,则执行ADD后: AL=90H,AF=1;再执行 DAA指令后,正确的结果为: AL=96H,CF=0, AF=1。MU
33、L BLAAM若执行前: AL=07, BL=09,则执行 MUL BL表 2-2十进制调整指令指令格式指令说明DAA压缩的 BCD码加法调整DAS压缩的 BCD码减法调整AAA 非压缩的 BCD码加法调整AAS非压缩的BCD码减法调整AAM乘法后的BCD码调整AAD除法前的BCD码调整后, AX=003FH,再执行 AAM指令后,正确的结果为:AH=06H,AL=03H。注意: BCD码进行乘除法运算时,一律使用无符号数形式,因而AAM和 AAD应固定地出现在MUL之前和 DIV 之后。三、逻辑运算和移位指令包括逻辑运算、移位和循环移位指令1逻辑运算指令(1)一般格式: NOT OPRD功能
34、:对操作数求反,然后送回原处,操作数可以是寄存器或存储器内容。此指令对标志无影响。例如:NOT AL(2)一般格式: AND OPRD1,OPRD2功能:对两个操作数进行按位的逻辑“与”运算,结果送回目的操作数。其中目的操作数 OPRD1可以是累加器、任一通用寄存器,或内存操作数 ( 所有寻址方式 ) 。源操作数 OPRD2可以是立即数、寄存器,也可以是内存操作数 ( 所有寻址方式 ) 。8086/8088 的 AND指令可以进行字节操作,也可以进行字操作。例如:AND AL ,0FH;可完成拆字的动作ANDSI,SI;将SI清0(3)一般格式: TEST OPRD1,OPRD2功能:完成与
35、AND指令相同的操作,结果反映在标志位上,但并不送回。通常使用它进行测试,例如 若要检测 AL 中的最低位是否为1,为 1 则转移。可用以下指令:TESTAL, 01H16JNZTHERETHERE:若要检测 CX中的内容是否为0,为 0 则转移。该如何做呢?(4)一般格式: OR OPRD1,OPRD2功能:对指定的两个操作数进行逻辑“或”运算。结果送回目的操作数。其中,目的操作数 OPRD1,可以是累加器,可以是任通用寄存器,也可以是一个内存操作数 ( 所有寻址方式 ) 。源操作数 OPRD2,可以是立即数、寄存器,也可以是内存操作数 ( 所有寻址方式 ) 。AND AL, 0FHAND
36、AH,0FOHORAL,AH; 完成拼字的动作ORAX,0FFFH ;将 AX低 12 位置 1ORBX,BX ;清相应标志(5)一般格式: XOROPRD1, OPRD2功能:对两个指定的操作数进行“异或”运算,结果送回目的操作数。其中,目的操作数OPRD1可以是累加器,可以是任一个通用寄存器,也可以是一个内存操作数 ( 全部寻址方式 ) 。源操作数可以是立即数、寄存器,也可以是内存操作数 ( 所有寻址方式 ) 。例如:XORAL,AL;使 AL清 0XORSI,SI;使 SI 清 0XOR CL,0FH;使低 4 位取反,高 4 位不变逻辑运算类指令中,单操作数指令NOT的操作数不能为立即
37、数,双操作数逻辑指令中,必须有一个操作数为寄存器寻址方式,且目的操作数不能为立即数。它们对标志位的影响情况如下:NOT不影响标志位,其它四种指令将使CF=OF=0,AF 无定义,而 SF、ZF 和 PF 则根据运算结果而定。2移位指令( 1)算术 / 逻辑移位指令 算术左移或逻辑左移指令SALSHL OPRD, M ;17 算术右移指令SAR OPRD,M 逻辑右移指令SHR OPRD,MM是移位次数,可以是1 或寄存器 CL这些指令可以对寄存器操作数或内存操作数进行指定的移位,可以进行字节或字操作;可以一次只移1 位,也可以移位由寄存器CL中的内容规定的次数( 2)循环移位指令ROL OPR
38、D,M ;左循环移位 ROR OPRD,M ;右循环移位RCL OPRD,M ;带进位左循环移位RCR OPRD,M ;带进位右循环移位前两条循环指令,未把标志位 CF包含在循环的环中,后两条把标志位 CF包含在循环的环中,作为整个循环的一部分。循环指令可以对字节或字进行操作。操作数可以是寄存器操作数,也可以是内存操作数。可以是循环移位一次,也可以循环移位由CL的内容所决定的次数。左移一位,只要左移以后的数未超出一个字节或一个字的表达范围,则原数的每一位的权增加了一倍,相当于原数乘 2。右移位相当于除以 2。在数的输入输出过程中乘 10 的操作是经常要进行的。 而 X10=X*2+X*8,也可
39、以采用移位和相加的办法来实现 *10 。为保证结果完整,先将 AL 中的字节扩展为字。MOVAH,0SALAX ,1; X*2MOVBX,AX;移至 BX中暂存SALAX ,1; X*4SALAX ,1; X*8ADDAX,BX;X*10例 1BCD码转换为 ASCII 码18若在内存某一缓冲区中存放着若干个单元的用BCD码表示的十进制数。每个单元中放两位BCD码,要求把它们分别转换为ASCII 码。高位的 BCD码转换完后放在地址较高的单元。分析:转换公式: ASCIIBCD+30H算法:源串和目的串的表首分别设两个指针。取BCD转 ASCII后存入(先低位,后高位)MOVSI ,OFFSE
40、T BCDBUFF;设置源地址指针MOVCX,COUNT;设计数初值MOV DI ,OFFSET ASCBUF;设置目的地址指针AGAIN: MOVAL, SIMOVBL,ALANDAL,0FH;取低位 BCD码ORAL,30H;转换成 ASCII 码MOVDI ,AL;存入INCDI;修改指针MOVAL,BLPUSH CXMOVCL,4SHRAL,CLORAL,30H;高位转换成 ASCII 码MOVDI ,AL;存入POPCXINCDIINCSI;修改指针LOOP AGAIN;重复工作习题与思考:1写出实现下列计算的指令序列。(假定 X、 Y、 Z、 W、 R 都为字变量)( 1)Z=(
41、W*X) / ( R+6)( 2) Z=( W-X) /5*Y )*22假定 DX=1100100110111001B, CL=3, CF=1,试确定下列各条指令单独执行后DX的值。( 1)SHRDX, 1( 2) SHLDL, 1( 3)SALDH, 1( 4) SARDX, CL( 5)RORDX, CL( 6) ROLDL, CL19( 7)RCRDL, 1( 8) RCLDX, CL3试分析下列程序完成什么功能?MOVCL,4SHLDX,CLMOVBL,AHSHLBL,CLSHRBL,CLORDL,BL4已知程序段如下:MOV AX,1234HMOV CL,4ROL AX,CLDEC
42、AXMOV CX,4MUL CXINT20H试问:( 1)每条指令执行后, AX寄存器的内容是什么?( 2)每条指令执行后, CF,SF及 ZF 的值分别是什么?( 3)程序运行结束时, AX及 DX寄存器的值为多少?第四讲:3.4指令系统 - 循环、子程序调用、中断、其他回顾: 8086/8088 的内部结构和寄存器,8086/8088 的工作过程8086/8088 的寻址方式及操作数地址的计算。重点和纲要: 要求学生了解串操作指令的功能。指令系统- 循环、子程序调用、中断、其他(掌握指令内涵,会用)20教学方法、实施步骤时间分配教学手段回顾5”× 2板书讲授35” ×2
43、计算机提问3” ×2投影仪小结2” ×2多媒体课件等讨论5” ×2讲授内容:四、串操作类指令(选讲或简单介绍)串操作类指令可以用来实现内存区域的数据串操作。这些数据串可以是字节串,也可以是字串。1重复指令前缀串操作类指令可以与重复指令前缀配合使用。从而可以使操作得以重复进行,及时停止。重复指令前缀的几种形式见表2-3 所示。表 2-3 重复前缀汇编格式执行过程影响指令REP(1)若 (CX) 0,则退出;(2)CX=CX-1;(3)执行后续指令;( 4)MOVS, STOS,重复( 1)-(3)LODSREPE/(1)若 (CX) 0 或 ZF=0,则退出;( 2
44、)CX=CX-1;(3)执行后续指CMPS, SCASREPZ令;( 4)重复( 1) - ( 3)REPNE/(1)若 (CX) 0 或 ZF=1,则退出;( 2)CX=CX-1;(3)执行后续指CMPS, SCASREPNZ令;( 4)重复( 1) - ( 3)2串指令串指令共有五种,具体见表2-4 。对串指令要注意以下几个问题:(1) 各指令所使用的默认寄存器是: SI (源串地址),DI(目的地址), CX(字串长度),AL(存取或搜索的默认值) 。(2) 源串在数据段,目的串在附加段。表 2-4串操作指令功能指令格式执行操作串传送MOVS DST, SRC由操作数说明是字节或字操作;
45、其余同MOVSB或 MOVSW21MOVSB(ES : DI) (DS : SI) ; SI=SI ± 1,DI=DI ±1; REP控制重复前两步MOVSW(ES : DI) (DS : SI) ; SI=SI ± 2,DI=DI ±2; REP控制重复前两步串比较CMPS DST, SRC由操作数说明是字节或字操作;其余同CMPSB或 CMPSWCMPSB(ES : DI) (DS :SI) ;SI=SI ±1,DI=DI ±1;重复前缀控制前两步CMPSW(ES : DI) (DS :SI) ;SI=SI ±2,DI=
46、DI ±2;重复前缀控制前两步串搜索SCAS DST由操作数说明是字节或字操作;其余同SCASB或 SCASWSCASBAL (ES : DI);DI=DI ± 1;重复前缀控制前两步SCASWAX (ES : DI); DI=DI ± 2;重复前缀控制前两步存串STOS DST由操作数说明是字节或字操作;其余同STOSB或 STOSWSTOSBAL (ES : DI);DI=DI ± 1;重复前缀控制前两步STOSWAX (ES : DI); DI=DI ± 2;重复前缀控制前两步取串LODS SRC由操作数说明是字节或字操作;其余同LODSB或 LODSWLO
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年全频道无线转播器项目可行性研究报告
- 2025至2030年高速单针锁式平缝机项目投资价值分析报告
- 2025至2030年捷达大灯开关项目投资价值分析报告
- 二零二五年度配电箱系统集成与优化服务合同
- 2025年全球及中国汽车智能踏板行业头部企业市场占有率及排名调研报告
- 建筑玻璃运输服务合同
- 二零二五年度货车司机职业健康管理与保障服务合同2篇
- 房地产行业购房合同法律咨询协议
- 房地产经纪行业房源信息免责协议
- 2024年生物科技项目开发合作协议
- 妇产科医生个人年终述职报告课件
- 《费曼学习法》读后感
- 趣味成语课程设计
- 幼儿园师资培训课件【区域进阶】科学区各年龄段目标制定与投放材料:区域材料玩出新高度课件
- DL∕T 1100.1-2018 电力系统的时间同步系统 第1部分:技术规范
- 以房抵债过户合同范本
- 重大版小学英语四年级下册期末测试卷
- 2024年1月高考适应性测试“九省联考”英语 试题(学生版+解析版)
- 一人出资一人出力合伙协议范本完整版
- 2022年北京海淀区高三一模物理试题和答案
- 施工工法的编写与申报(完整版)
评论
0/150
提交评论