微机原理与接口技术汇编语言指令详解吐血版.docx

上传人:罗晋 文档编号:11683509 上传时间:2021-08-30 格式:DOCX 页数:33 大小:142.73KB
返回 下载 相关 举报
微机原理与接口技术汇编语言指令详解吐血版.docx_第1页
第1页 / 共33页
微机原理与接口技术汇编语言指令详解吐血版.docx_第2页
第2页 / 共33页
微机原理与接口技术汇编语言指令详解吐血版.docx_第3页
第3页 / 共33页
微机原理与接口技术汇编语言指令详解吐血版.docx_第4页
第4页 / 共33页
微机原理与接口技术汇编语言指令详解吐血版.docx_第5页
第5页 / 共33页
点击查看更多>>
资源描述

《微机原理与接口技术汇编语言指令详解吐血版.docx》由会员分享,可在线阅读,更多相关《微机原理与接口技术汇编语言指令详解吐血版.docx(33页珍藏版)》请在三一文库上搜索。

1、19例如:MOV AX 3000HAH0030第一讲第三章 指令系统-寻址方式回顾:8086/8088的内部结构和寄存器,地址分段的概念,8086/8088的工作过程。重点和纲要:指令系统-寻址方式。有关寻址的概念;6种基本的寻址方式及有效地址的计算。教学方法、实施步骤时间分配教学手段回顾5” X 2板书计算机投影仪多媒体课件等讲授40” X2提问3”X 2小结2” X 2讲授内容:3.1 8086/8088 寻址方式首先,简单讲述一下指令的一般格式:操作码操作数操作数计算机中的指令由操作码字段和操作数字段组成。操作码:指计算机所要执行的操作,或称为指出操作类型,是一种助记符。操作数:指在指令

2、执行操作的过程中所需要的操作数。该字段除可以是操作数本身外,也可以是操作数地址或是地址的一部分,还可以是指向操作数地址的 指针或其它有关操作数的信息。寻址方式就是指令中用于说明操作数所在地址的方法,或者说是寻找操作数 有效地址的方法。8086/8088的基本寻址方式有六种 1.立即寻址所提供的操作数直接包含在指令中。它紧跟在操作码操作码的后面,与操作码一起放在代码段区域中。立即数可以是8位的,也可以是16位的。若是16位的,则存储时低位在前, 局位在后。立即寻址主要用来给寄存器或存储器赋初值。2 .直接寻址操作数地址的16位偏移量直接包含在指令中。它与操作码一起存放在代码段区域,操作数一般在数

3、据段区域中,它的地址为数据段寄存器DS加上这16位地址偏移量。如图2-2所小。例如:MOV AX, DS 2000H;3 0 0 0代码段骸据葭图2 2(对DS来讲可以省略成 MOV AX, 2000H,系统默认为数据段)这种寻址方法是以数据段的地址为基础,可在多达64KB的范围内寻找操作数。8086/8088中允许段超越,即还允许操作数在以代码段、堆栈段或附加段为 基准的区域中。此时只要在指令中指明是段超越的,则16位地址偏移量可以与CS或SS或ES相力口,作为操作数的地址。MOV AX, 2000H;数据段MOV BX, ES: 3000H;段超越,操作数在附加段即绝对地址=(ES)* 1

4、6+ 3000H3 .寄存器寻址操作数包含在CPU勺内部寄存器中,如寄存器 AX BX CX DX等。例如:MOV DS AXMOV AL BH4 .寄存器间接寻址操作数是在存储器中,但是,操作数地址的16位偏移量包含在以下四个寄存器SI、DI、BP、BX之一中。可以分成两种情况:(1) 以SI、DI、BX间接寻址,则 通常操作数在现行数据段区域中,即数据段寄存器(DS * 16 加上SI、DI、BX中的16位偏移 量,为操作数的地址,例如:MOV AX, SI 操作 数地址是:(DS *16+ (SI)(2) 以寄存器BP间接寻址,则操作数在堆栈段区域中。即堆栈段寄存器(SS)* 16与BP

5、的内容相加作为操作数的地址,例如:MOV AX BP操作数地址是:(SS)*16+ (BP)若在指令中规定是段超越的,则BP的内容也可以与其它的段寄存器相加, 形 成操作数地址。例如: MOV AX, DS BP操作数地址是:(DS)*16+ (BP3)5 .变址寻址由指定的寄存器内容,加上指令中给出的8位或16位偏移量(当然要由一个段寄存器作为地址基准)作为操作数的偏移地址。(操作数在存贮器中)可以作为寄存器变址寻址的四个寄存器是 SI、DI、BX BR若用SI、DI和BX作为变址,则与数据段寄存器相加,形成操作数的地址即默 认在数据段;若用BP变址,则与堆栈段寄存器相加,形成操作数的地址即

6、默认在堆栈段例如: MOV AX , COUNTSI;操作数地址是:(DS)*16+ (SI) +COUNT但是,只要在指令中指定是段超越的,则可以用别的段寄存器作为地址基准。6 .基址加变址寻址3 4 0 0 0AL 3i000代码隆数据段把BX和BP看成是基址寄存器,把 SI、DI看着是变址寄存器,把一个基址 寄存器(BX或BP)的内容加上一个变址 寄存器(SI或DI)的内容,再加上指令 中指定的8位或16位偏移量(当然要以 一个段寄存器作为地址基准)作为操作数的偏移地址,如图所示。操作数在存贮器中,其偏移地址由(基址寄存器)+ (变址寄存器)+相对 偏移量形成基址寄存器一一BX数据段、B

7、R堆栈段;变址寄存器 SI、DI。例如:MOV AX , BXSI 或 MOV AX , BX+SI也可放置一个相对偏移量,如 COUNT MAS等,用于表示相对寻址。MOV AX, MASKBXSIMOV BH, COUNTDIBP; MOV BH, COUNTBP+DI若用BX作为基地址,则操作数在数据段区域若用BP作为基地址,则操作数在堆栈段区域但若在指令中规定段是超越的,则可用其它段寄存器作为地址基准。P . 28表2-1段寄存器使用的基本约定访问存储器类型默认段寄存器可指定段寄存器段内偏移地址来源取指令码CS无IP堆栈操作SS无SP串操作源地址DSCS ES SSSI串操作目的地址E

8、S无DIBP用作基址寄存器SSCS DS ES根据寻址方式求得有效地址一般数据存取DSCS ES SS根据寻址方式求得有效地址习题与思考:1 .假定 DS=2000H ES=2100H SS=1500H SI=00A0H, BX=0100H BP=0010H 数据变量 VAL的偏移地址为0050H,请指出下列指令源操作数是什么寻址方式?其物理地址是多少?(1) MOV AX , 0ABH(2) MOVAX, 100H(3) MOXAX, VAL(4) MOV BX,SI(5) MOXAL, VALBX(6) MOV CL,BXSI MOWALSI , BX(8) MOVBPSI , 1002.

9、已知SS=0FFA0H SP=00B0H先执行两条把 8057H和0F79H分别进栈的 PUSH旨令,再执行一条POP旨令,试画出堆栈区和 SP内容变化的过程示意图。(标出存储单元的地址)第二讲3.2 指令系统-数据传输、算术运算回顾:8086/8088的内部结构和寄存器,8086/8088的工作过程8086/8088的寻址方式及操作数地址的计算。重点和纲要:要求学生了解指令的功能,掌握数据传送类,算术运算 类指令的使用方法。(掌握指令内涵,会用)教学方法、实施步骤时间分配教学手段回顾5” X 2板书计算机投影仪多媒体课件等讲授40” X2提问3”X 2小结2” X 2讲授内容:3.2 808

10、6/8088指令系统8086/8088的指令系统可以分为以下六个功能组。1.数据传送(Data Transter) 2.算术运算(Arithmetic)3.逻辑运算(Logic) 4.用操作(String menipulation)5.程序控制(Program Control) 6.处理器控制(Processor Control)一、数据传送指令主要介绍MOV XCHG堆栈和地址传送指令。1 .数据传送MOV旨令一般格式: MOV OPRD,1 OPRD2MOV是操作码,OPRD和OPRD分别是目的操作数和源操作数。功能:完成数据传送具体来说,一条数据传送指令能实现:CPU内部寄存器之间数据的

11、任意传送(除了代码段寄存器CS和指令指针IP以外)。MOV AL BL;字节传送MOV CX BX;字传送MOV DS, BX立即数传送至CPUrt部的通用寄存器组(即AX BX、CX DX BR SP、SI、DI),MOV CL, 4MOV AX, 03FFHMOV SI, 057BHCPUfi部寄存器(除了 CS?口 IP以外)与存储器(所有寻址方式)之间的数据传送。MOV AL, BUFFERMOV AX, SIMOV DI , CXMOV SI, BLOCKBPMOV DS, DATASI+BXMOV DESTBP+DI, ES 能实现用立即数给存储单元赋值例如: MOV 2000H

12、, 25HMOV SI , 35H对于MOV旨令应注意几个问题:存储器传送指令中,不允许对 CS?口 IP进行操作;两个操作数中,除立即寻址之外必须有一个为寄存器寻址方式,即两个存储器操作数之间不允许直接进行信息传送;如我们需要把地址(即段内的地址偏移量)为AREAl的存储单元的内容,传送 至同一段内的地址为AREA2勺存储单元中去,MOV旨令不能直接完成这样的传送, 但我们可以用CPUfi部寄存器为桥梁来完成这样的传送:MOV AL , AREAlMOV AREA2AL两个段寄存器之间不能直接传送信息,也不允许用立即寻址方式为段寄存器赋初值;如:MOV AX, 0; MOV D AX目的操作

13、数,不能用立即寻址方式。2 .堆栈指令(简述堆栈的概念及存取特点,如先进后出)包括入栈(PUSH和出栈(POP指令两类。仅能进行字运算。(操作数不能 是立即数)入栈指令PUSH一般格式:PUSH OPRD源操作数可以是CPU内部的16位通用寄存器、段寄存器(CS除外)和内存操作数(所有寻址方式)。入栈操作对象必须是16位数。功能:将数据压入堆栈执行步骤为:SP=SP-2母巳=操作数低8位;SP+1=操作数高8位例如:PUSH BX执行过程为:SP=SP-1, SP=BH; SP=SP-1, SP=BL,如图2-8所示。SF-2SF=SP-2凯SP-1SF=SP-1住 HSPK执行前执行后图2-

14、8 出栈指令POP一般格式:POP OPRD功能:将数据弹出堆栈对指令执行的要求同入栈指令。例如:POP AXPOP BXPOP DS3 .交换指令 XCHG一般格式:XCHG OPRD1OPRD2功能:完成数据交换这是一条交换指令,把一个字节或一个字的源操作数与目的操作数相交换。交换能在通用寄存器与累加器之间、通用寄存器之间、通用寄存器与存储器之间 进行。但段寄存器和立即数不能作为一个操作数,不能在累加器之间进行例如:XCHG AL, CL XCHG AX DI XCHG BX SI XCHG AX BUFFER XCHG DATASI, DH4 .累加器专用传送指令有三种,输入、输出和查表

15、指令。前两种又称为输入输出指令。IN指令一般格式:INAL,n;B AL nINAX,n;W AXn+1nINAL,DX;B AL DXINAX,DX ;W AX DX+1DX功能:从I/O端口输入数据至AL或AX输入指令允许把一个字节或一个字由一个输入端口传送到 AL或AX中。若端 口地址超过255时,则必须用DX保存端口地址,这样用 DX作端口寻址最多可寻 找64K个端口。OUT指令一般格式:OUT n, AL ; B AL 一nOUT n , AX ; W AX -n+1nOUT DX , AL ; B AL 一 DXOUT DX , AX ; W AX -DX+1DX功能:将AL或AX

16、的内容输出至I/O端口。该指令将AL或AX中的内容传送到一个输出端口。端口寻址方式与IN指 令相同。(3) XLAT 指令一般格式:XLAT ; AL=(DX) X 16+ (BX)+ (AL)功能:完成一个字节的查表转换。要求:寄存器AL的内容作为一个256字节的表的下标。表的基地址在BX中,TABLE:转换后的结果存放在 AL中.例如:MOV BX, OFFSET TABLEMOV AL, 8IN AL , 1第9个字符 AAHXLAT ;查表OUT 1 , AL ; (AL) = AAH表长56本指令可用在数制转换、函数表查表、代码转换等场合。5.地址传送指令(有三条地址传送指令)(1)

17、 LEA (Load Effective Address)一般格式:LEA OPRD1 OPRD2功能:把源操作数OPRD妁地址偏移量传送至目的操作数 OPRD1要求:源操作数必须是一个内存操作数,目的操作数必须是一个16位的通用寄存器。这条指令通常用来建立用操作指令所须的寄存器指针。例:LEA BX, BUFR把变量BUFR勺地址偏移量部分送至U BX LDS (Load pointer into DS)股格式:LDS OPRD1, OPRD2功能:完成一个地址指针的传送。地址指针包括段 地址部分和偏移量部分。指令将段地址送入 DS 偏移量部分送入一个16位的指针寄存器或变址寄 存器。要求:

18、源操作数是一个内存操作数,目的操作数是 一个通用寄存器/变址寄存器。例如:LDSSI, BX;将把BX所指的32位地址指针的段地址部分送入 D偏移量部分送入 SI。图2-9 LDS指令示意如图2-9所示。(3) LES (Load pointer into ES)一般格式:LES OPRD1, OPRD2这条指令除将地址指针的段地址部分送入 ES外,与LDS类似。例如:LESDI, BX+COUNT 6.标志寄存器传送(有四条标志传送指令)(1) LAHF (LOAD AH WITH FLAG)将标志寄存器中的SF、ZF、AF、PF和CF (即低8位)传送至AH寄存器的指 定位,空位没有定义。

19、(2) SAHF (STORE AH WITH FLAG)将寄存器AH的指定位,送至标志寄存器的 SF、ZF、AF、PF和CF位(即低8 位)。根据AH的内容,影响上述标志位,对 OR DF和IF无影响。(3) PUSHF (PUSH FLAG将标志寄存器压入堆栈顶部,同时修改堆栈指针,不影响标志位。(4) POPF (POP FLAG堆栈顶部的一个字,传送到标志寄存器,同时修改堆栈指针,影响标志位。二、算术运算指令8086/8088 提供加、减、乘、除四种基本算术操 作。这些操作都可用于字节 或字的运算,也可以用于带 符号数与无符号数的运算。带符号数用补码表示。同时8086/8088也提供了

20、各种校正操作,故可以进行十进制算术运算 参与加、减运算的操作数可如上图所示。1.加法指令(Addition)一般形式:ADD OPRD10PRD2功能:OPRD1OPRD1+OPRD2完成两个操作数相加,结果送至目的操作数OPRD1目的操作数可以是累加器,任一通用寄存器以及存储器操作数。例如:ADD AL, 30;累加器与立即数相加ADD BX, 3000H;通用寄存器与存储单元内容相加ADD DI, CX通用寄存器之间ADD DX DATABX+SI;通用寄存器与存储单元内容相加ADD BETASI, DX存储器操作数与寄存器相加这些指令对标志位 CR DR PF、SF、ZF和AF有影响。一

21、般形式:ADC OPRD1 OPRD2带进位的力口法功能:OPRD1OPRD1+OPRD2 +CF这条指令与上条指令类似,只是在两个操作数相加时,要把进位标志CF的现行值加上去,结果送至目的操作数。ADC旨令主要用于多字节运算中。若有两个四字节的数,已分别放在自FIRST 和SECONDS始的存储区中,每个数占四个存储单元。存放时,最低字节在地址 最低处,则可用以下程序段实现相加。MOV AX, FIRSTADD AX, SECOND1 行字运算MOV THIRD, AXMOV AX, FIRST+2ADC AX, SECOND+2MOV THIRD+,2 AX这条指令对标志位的影响与 ADD

22、同。一般形式: INC OPRD ;功能:OPRDOPRD+1完成对指定的操作数 OPRCta 1,然后返回此操作数。此指令主要用于在循环 程序中修改地址指针和循环次数等。这条指令执行的结果影响标志位 AF、OR PF、SF和ZF,而对进位标志没有 影响。如: INC ALINC BX2减法指令(Subtraction)一般形式:SUB OPRD,1OPRD2 ;功能:OPRD1OPRD1-OPRD2完成两个操作数相减,也即从 OPRD中减去OPRD2结果放在OPRD仲。例如: SUB CX, BXSUB BP , CL一般形式: SBB OPRD,1 OPRD2 ;功能:OPRD1OPRD1

23、-OPRD2-CF这条指令与SU联似,只是在两个操作数相减时,还要减去借位标志CF的现行值.本指令对标志位 AF、CF、OR PF、SF和ZF都有影响。同ADC旨令一样,本指令主要用于多字节操作数相减。一般形式: DEC OPRD ;功能:OPRDOPRD-1-CF对指令的操作数减1,然后送回此操作数,在相减时,把操作数作为一个无符号二进制数来对待。指令执行的结果,影响标志AF、OR PF、SF和ZF.但对CF标志不影响(即保持此指令以前的值)。例如: DEC SIDEC CL一般形式: NEG OPRD功能:(NEGDate)取补对操作数取补,即用零减去操作数,再把结果送回操作数。例如:NE

24、G ALNEG MULRE(AL= 0011 1100)则取补后为 1100 0100即 0000 0000 0011 1100= 1100 0100若在字节操作时对-128 ,或在字操作时对-32768 取补,则操作数没变化,但标志OF置位。此指令影响标志AF、CR OR PF、SF和ZF。此指令的结果一般总是使标志CF=1。除非在操作数为零时,才使 CF=Q一般形式: CMP OPRD, 1OPRD2 ;功能: OPRD1-OPRD2比较指令完成两个操作数相减, 使结果反映在标志位上, 但并不送回结果( 即不带回送的减法) 。例如: CMP AL , 100CMP DX, DICMP CX

25、, COUHTBPCMP COUNTSI, AX比较指令主要用于比较两个数之间的关系。在比较指令之后,根据ZF 标志即可判断两者是否相等。相等的比较:若两者相等,相减以后结果为零,ZF标志为1,否则为00若两者不相等,则可在比较指令之后利用其它标志位的状态来确定两者的大小。大小的比较:如果是两个无符号数(如CMP AX, BXX进行比较,则可以根据CF标志的状 态判断两数大小。若结果没有产生借位(CF=0),显然AXBX;若产生了借位(即 CF= 1),则 AX BX习题与思考:1 设有关寄存器及存储单元的内容如下:DS=2000H, BX=0100H, AX=1200H, SI=0002H,

26、 20100H=12H , 20101H=34H , 20102H=56H , 20103=78H , 21200=2AH , 21201H=4CH , 21202H=0B7H , 21203H=65H 。试说明下列各条指令单独执行后相关寄存器或存储单元的内容。( 1) MOVAX, 1800H( 3) MOVBX, 1200H( 5) MOV BXSI , AL 2 写出实现下列计算的指令序列。( 2) MOVAX, BX(4) MOVDX, 1100BX(6) MOVAX, 1100BXSI1) Z=W+( Z+X)2) Z=W-(X+6) - ( R+9)(假定X、Y Z、W R都为字变

27、量)3 .若在数据段中从字节变量TABLE相应的单元开始存放了015的平方值,试写出包含有XLAT指令的指令序列查找N( 015)中的某个数的平方。 ( 设 N 的值存放在 CL 中 )第三讲3.3 指令系统 - 算术运算、逻辑运算、控制转移回顾: 8086/8088 的内部结构和寄存器, 8086/8088 的工作过程。8086/8088 的寻址方式及操作数地址的计算。重点和纲要: 要求学生了解指令的功能,掌握算术运算类、逻辑运算和移位指令的功能和应用。 (掌握指令内涵,会用)教学方法、实施步骤时间分配教学手段回顾5” X 2板书计算机投影仪多媒体课件等讲授40” X2提问3”X 2小结2”

28、 X 2讲述内容:3 .乘法指令(分为无符号乘法指令和带符号乘法指令两类)(1)无符号乘法指令MUL一般格式:MUL OPRD完成字节与字节相乘、字与字相乘,且默认的操作数放在AL或AX中,而源操作数由指令给出。8位数相乘,结果为16位数,放在AX中;16位数相乘 结果为32位数,高16位放在DX,低16位放在AX中。注意:源操作数不能为 立即数。例如:MOV AL FIRST;MUL SECOND ;结果为 AX=FIRST*SECONDMOV AX, THIRDMUL AX;结果 DX AX=THIRD*THIRDMOV AL, 30HCBW;字扩展 AX=30HMOV BX, 2000H

29、MUL BX ;(2)带符号数乘法指令IMUL一般格式:IMUL OPRD ; OPRD为源操作数这是一条带符号数的乘法指令,同 MUL样可以进行字节与字节、字和字的 乘法运算。结果放在AX或DX, AX中。当结果的高半部分不是结果的低半部分的 符号扩展时,标志位CF和OF将置位。4 .除法指令(1)无符号数除法指令DIV一般格式:DIV OPRD(2)带符号数除法IDIVIDIV OPRD该指令执行过程同 DIV 指令,但 IDIV 指令认为操作数的最高位为符号位,除法运算的结果商的最高位也为符号位。在除法指令中,在字节运算时被除数在 AX中;运算结果商在AL中,余数在 AH中。字运算时被除

30、数为DX AX构成的32位数,运算结果商在 AX中,余数在 DX中。例如:AX=2000H DX=200H BX=1000H 贝U DIV BX执行后,AX=2002H , DX=0000 除法运算中,源操作数可为除立即寻址方式之外的任何一种寻址方式,且指令执行对所有的标志位都无定义。由于除法指令中的字节运算要求被除数为 16 位数,而字运算要求被除数是32位数,在8086/8088 系统中往往需要用符号扩展的方法取得被除数所要的格式,因此指令系统中包括两条符号扩展指令。(3) 字节扩展指令CBW一般格式: CBW该指令执行时将AL寄存器的最高位扩展到 AH,即若D7=Q则AH=0否则 AH=

31、0FFH。(4) 字扩展指令CWD一般格式: CWD该指令执行时将AX寄存器的最高位扩展到DX,即若D15=Q则DX=0否则 DX=0FFFFHCBW CW时令不影响标志位。5十进制调整指令计算机中的算术运算,都是针对二进制数的运算,而人们在日常生活中习惯使用十进制。为此在8086/8088 系统中,针对十进制算术运算有一类十进制调整指令。在计算机中人们用BC则表示十进制数,对BCM计算机中有两种表示方法: 一类为压缩BC则,即规定每个字节表示两位 BCC;另一类称为非压缩BCD马, 即用一个字节表示一位BCDt在这字节的高四位用0填充。例如,十进制数25D, 表示为压缩BCEB时为:25H;

32、表示为非压缩BCD&时为:0205H,用两字节表示。相关的BCD专换指令见表2-2。例如:表2-2十进制调整指令ADD AL, BL指令格式指令说明DAADAA压缩的BCD加法调整若执行前:AL=28H BL=68H则执行ADDDAS压缩的BCD减法调整后:AL=90H AF=1;再执行DAA指令后,正确AAA非压缩的BCM加法调整的结果为:AL=96H CF=Q AF=tAAS非压缩的BC网减法调整MUL BLAAM乘法后的BCM调整AAMAAD除法前的BCM调整若执行前:AL=07, BL=09,则执行MUL BL后,AX=003FH再执行AAM旨令后,正确的结果为:AH=06H AL=0

33、3H注意:BCM进行乘除法运算时,一律使用无符号数形式,因而 AAM和AAD 应固定地出现在MU叱前和DIV之后。三、逻辑运算和移位指令包括逻辑运算、移位和循环移位指令1 .逻辑运算指令(1) 一般格式:NOT OPRD功能:对操作数求反,然后送回原处,操作数可以是寄存器或存储器内容。此指令对标志无影响。例如:NOT AL(2) 一般格式:AND OPRD 1 OPRD2功能:对两个操作数进行按位的逻辑“与”运算,结果送回目的操作数。其中目的操作数 OPRD可以是累加器、任一通用寄存器,或内存操作数 (所 有寻址方式)。源操作数OPRD2T以是立即数、寄存器,也可以是内存操作数 (所 有寻址方

34、式)。8086/8088的AND旨令可以进行字节操作,也可以进行字操作。例如:AND AL, 0FH ;可完成拆字的动作AND SI, SI ; 将 SI 清 0(3) 一般格式:TEST OPRD 1 OPRD2功能:完成与AND旨令相同的操作,结果反映在标志位上,但并不送回。通 常使用它进行测试,例如 若要检测AL中的最低位是否为1,为1则转移。可用以下指令:TEST AL, 01HJNZ THERETHERE若要检测CX中的内容是否为0,为0则转移。该如何做呢?(4) 一般格式:OR OPRD1 OPRD2功能:对指定的两个操作数进行逻辑“或”运算。结果送回目的操作数。其中,目的操作数

35、OPRD累可以是累加器,可以是任一通用寄存器,也可以 是一个内存操作数(所有寻址方式)。源操作数OPRD2可以是立即数、寄存器, 也可以是内存操作数(所有寻址方式)。AND AL, 0FHAND AH 0FOHORAL, AH ;完成拼字的动作ORAX, 0FFFH ;将 AX低 12 位置 1ORBX, BX ; 清相应标志(5) 一般格式:XOR OPRD,1 OPRD2功能:对两个指定的操作数进行“异或”运算,结果送回目的操作数。其中,目的操作数OPRD1T以是累加器,可以是任一个通用寄存器,也可以 是一个内存操作数(全部寻址方式)。源操作数可以是立即数、寄存器,也可以是 内存操作数(所

36、有寻址方式)。例如:XOR AL, AL ;使 AL清 0XOR SI, SI ;使 SI 清 0XOR CL, 0FH;使低4位取反,高4位不变逻辑运算类指令中,单操作数指令 NOT勺操作数不能为立即数,双操作数逻 辑指令中,必须有一个操作数为寄存器寻址方式,且目的操作数不能为立即数。SXL/SHL NO 操作数 LST CF -4 0(也)SAR IH5B 旗沱数 LSB它们对标志位的影响情况如下:NOT影响标志位,其它四种指令将使 CF=OF=0 AF无定义,而SF、ZF和PF则根据运算结果而定。2 .移位指令(1)算术/逻辑移位指令算术左移或逻辑左移指令SAL/SHL OPRR M ;

37、 算术右移指令SAR OPRD , M逻辑右移指令SHR OPRD , MM是移位次数,可以是1或寄存器CL这些指令可以对寄存器操作数或内存操作数进行指定的移位,可以进行字节 或字操作;可以一次只移1位,也可以移位由寄存器 CL中的内容规定的次数(2)循环移位指令ROL OPRD M;左循环移位ROR OPR DM;右循环移位RCL OPRD M ;带进位左循环移位前两条循环指令,未把标志操作数即艮辟作数操作数ECRI-* CFb )操作数RCR OPRD M ;带进位右循环移位位CF包含在循环 的环中,后两条 把标志位CF包含 在循环的环中,作为整个循环的一部分。循环指令可以对字节或字进行操

38、作。操作数可以是寄存器操作数,也可以是内存操作数。可以是循环移位一次,也可以循环移位由CL的内容所决定的次数左移一位,只要左移以后的数未超出一个字节或一个字的表达范围,则原数 的每一位的权增加了一倍,相当于原数乘 2。右移一位相当于除以2。在数的输入输出过程中乘10的操作是经常要进行的。而X10=X*2+X*&也可 以采用移位和相加的办法来实现*10o为保证结果完整,先将 AL中的字节扩展为MOV AH, 0SAL AX , 1; X*2MOV BX, AX ;移至BX中暂存SAL AX , 1; X*4SAL AX , 1; X*8ADD AX, BX ; X*10例1 BCD码转换为ASC

39、II码若在内存某一缓冲区中存放着若干个单元的用 BCD进表示的十进制数。每一 个单元中放两位BC则,要求把它们分别转换为 ASCII码。高位的BCD转换完 后放在地址较高的单元。分析:转换公式:ASCII = BCD+30H算法:源用和目的用的表首分别设两个指针。取BCD专ASCII后存入(先低位,后高位)MOV SI , OFFSETMOV CX, COUNTMOV DI , OFFSETAGAIN: MOVAL, SIMOV BL, ALAND AL, 0FHOR AL, 30H MOV DI , ALINC DIMOV AL, BLPUSH CXMOV CL, 4SHRAL, CLOR

40、AL, 30H MOV DI , ALPOPCXINCDIINCSILOOP AGAINBCDBUF F设置源地址指针;设计数初值ASCBUF;设置目的地址指针;取低位BC则ASCII 码;存入;修改指针ASCII 码;存入;修改指针;重复工作331 写出实现下列计算的指令序列。DX的值。习题与思考:1)SHRDX,1( 2)SHLDL,13)SALDH,1( 4)SARDX,CL5)RORDX,CL( 6)ROLDL,CL( 1) Z=( W*X) / ( R+6)(假定X、Y Z、W R都为字变量)( 2) Z=( W-X) /5*Y ) *22 .假定DX=110010011011100

41、1R CL=3, CF=1,试确定下列各条指令单独执行后7) RCR DL, 1( 8) RCLDX, CL3 试分析下列程序完成什么功能?MOVCL,4SHLDX,CLMOVBL,AHSHLBL,CLSHRBL,CLORDL,BL4 已知程序段如下:MOV AX, 1234HMOV CL, 4ROL AX, CLDEC AXMOV CX, 4 MUL CXINT 20H试问:(1)每条指令执行后,AX寄存器的内容是什么? ( 2)每条指令执行后,CF, SF及ZF 的值分别是什么? ( 3)程序运行结束时,AX及DX寄存器的值为多少?第四讲:3.4 指令系统 -循环、子程序调用、中断、其他回

42、顾: 8086/8088 的内部结构和寄存器, 8086/8088 的工作过程8086/8088 的寻址方式及操作数地址的计算。重点和纲要: 要求学生了解串操作指令的功能。指令系统 - 循环、子程序调用、中断、其他(掌握指令内涵,会用)教学方法、实施步骤时间分配教学手段回顾5” X 2板书计算机投影仪多媒体课件等讲授35” X2提问3”X 2小结2” X 2讨论5”X 2讲授内容:四、 串操作类指令 (选讲或简单介绍)用操作类指令可以用来实现内存区域的数据用操作。这些数据用可以是字节 用,也可以是字用。1 .重复指令前缀用操作类指令可以与重复指令前缀配合使用。从而可以使操作得以重复进 行,及时

43、停止。重复指令前缀的几种形式见表 2-3所示。表2-3重复前缀汇编格式执行过程影响指令REP(1)若(CX)=0,则退出;(2) CX=CX-1; (3)执行后续指令;(4) 重复(1)-(3)MOVS STOS, LODSREPE/REPZ(1)若(CX)=0或ZF=0,则退出;(2) CX=CX-1; (3)执行后续指令;(4)重复(1) - (3)CMPS SCASREPNE/REPNZ(1)若(CX)=0或ZF=1,则退出;(2) CX=CX-1; (3)执行后续指令;(4)重复(1) - (3)CMPS SCAS2 .用指令用指令共有五种,具体见表2-4。对用指令要注意以下几个问题:(1)各指令所使用的默认寄存器是:SI (源用地址),DI (目的地址),CX (字串 长度),AL (存取或搜索的默认值)。(2)源用在数据段,目的用在附加段。表2-4 串操作指令功能指令格式执行操作串传送MOVS DST SRC由操作数说明是字节或字操作;其余同MOVS或MOVSWMOVSBMOVSW(ES : DI) (DS: SI) ; SI=SI1, DI=DI1; REP空制重复前两步(ES : DI) (DS: SI) ; SI=SI2, DI=DI2; REP空制重复前两步串比较CMPS DST S

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 科普知识


经营许可证编号:宁ICP备18001539号-1