书签 分享 收藏 举报 版权申诉 / 53
上传文档赚钱

类型《汇编语言程序设计》-相伟-电子教案第4章课件.ppt

  • 上传人(卖家):晟晟文业
  • 文档编号:4145463
  • 上传时间:2022-11-14
  • 格式:PPT
  • 页数:53
  • 大小:153.24KB
  • 【下载声明】
    1. 本站全部试题类文档,若标题没写含答案,则无答案;标题注明含答案的文档,主观题也可能无答案。请谨慎下单,一旦售出,不予退换。
    2. 本站全部PPT文档均不含视频和音频,PPT中出现的音频或视频标识(或文字)仅表示流程,实际无音频或视频文件。请谨慎下单,一旦售出,不予退换。
    3. 本页资料《《汇编语言程序设计》-相伟-电子教案第4章课件.ppt》由用户(晟晟文业)主动上传,其收益全归该用户。163文库仅提供信息存储空间,仅对该用户上传内容的表现方式做保护处理,对上传内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!
    4. 请根据预览情况,自愿下载本文。本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
    5. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007及以上版本和PDF阅读器,压缩文件请下载最新的WinRAR软件解压。
    配套讲稿:

    如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。

    特殊限制:

    部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。

    关 键  词:
    汇编语言程序设计 汇编语言 程序设计 相伟 电子 教案 课件
    资源描述:

    1、21世纪高等院校规划教材汇编语言程序设计相 伟 主编徐小平 李珍香 副主编中国水利水电出版社第4章 分支程序设计n本章主要讲解分支程序设计的基本思想和设计方法。通过本章学习,读者应掌握以下内容:n段内寻址与段间寻址n无条件转移指令n条件转移指令n二分支程序设计方法n多分支程序设计方法4.1 转移地址的寻址方式nIntel 8086/8088CPU中,程序的执行顺序是由代码段寄存器CS和指令指针IP确定的。CS包含当前指令所在代码段的段地址,IP则是要执行的下一条指令的偏移地址。通常情况下,程序是顺序执行的,即CPU取出指令后,自动形成下一条指令的地址,依指令序列顺序执行。但有时需要改变程序的流

    2、程,这就要给出目标指令的段地址(CS)和偏移地址(IP)值,这就是与转移地址有关的寻址方式。n与转移地址有关的寻址方式有四种:段内直接寻址、段内间接寻址、段间直接寻址和段间间接寻址。4.1.1 段内寻址n段内寻址分为段内直接寻址和段内间接寻址两种方式。其转移方式是在当前代码段64KB范围内转移,因此不需要更改段地址CS的值,只要改变偏移地址IP的值即可。1段内直接寻址n指令中直接给出转移地址的偏移量(8位或16位),转移目标与转移指令在同一段内。转移指令执行后,CS值保持不变。转移的有效地址为当前的IP值与指令中指定的偏移量之和。即n 目标地址=IP(当前值)+偏移量n其中偏移量为8位或16位

    3、有符号数。若偏移量为正数,向前转移(即高地址方向);若偏移量为负数,则向后转移(即低地址方向)。另外,对8位偏移量,其转移范围为-128 +127,称为短转移;对16位偏移量,其转移范围为-32768 +32767,称为近转移。n短转移指令为2字节指令,IP的当前值为转移指令所在的IP值加2。近转移指令为3字节指令,IP的当前值为转移指令所在的IP值加3。例4-1:分析下列指令。n JMP SHORT DSP1 ;短转移指令n JMP NEAR PTR DSP2 ;近转移指令n假设两条指令存放地址均为1000H:0200H,偏移量DSP1为08H,偏移量DSP2为0012H。n短转移指令执行时

    4、,当前IP值=0200H+2=0202H。目标地址=IP(当前值)+偏移量=0202H+08H=020AH 指令执行后将转向1000H:020AH去执行。n近转移指令执行时,当前IP值=0200H+3=0203H。目标地址=IP(当前值)+偏移量=0203H+0012H=0215H 指令执行后将转向1000H:0215H去执行。2段内间接寻址n与段内直接寻址方式相同,转移目标与转移指令在同一段内。转移指令执行后,CS值保持不变。与段内直接寻址方式不同的是,转移的有效地址值存放在16位的通用寄存器或连续两个存储单元中。若有效地址在存储单元中,一定要指出存储单元为字型。例4-2:假设(DS)=20

    5、00H,(BX)=3000H,(23000H)=2536H,分析下列指令。nJMP BX 指令执行后,将BX的内容直接赋给IP。所以,(IP)=3000H。nJMP WORD PTRBX 指令执行后,先计算出存储单元地址23000H,再从该单元中取出内容送给IP。所以,(IP)=2536H。4.1.2 段间寻址n段间寻址分为段间直接寻址和段间间接寻址两种方式。其转移方式是从当前代码段跳转到另一个代码段,因此需要修改CS段地址和IP偏移地址的值。1段间直接寻址n在指令中直接给出了转移目标的段地址和偏移地址。只要用指令中指定的偏移地址代替IP寄存器的内容,用指令中指定的段地址代替段寄存器CS的内容

    6、就可以完成从一个段到另一个段的转移操作。段间直接转移通常叫远转移(far jump),指令的操作数必须附加FAR PTR操作符。例4-3:执行如下指令n JMP FAR PTR DSPn假设指令存放地址为1000H:0200H,DSP的有效地址为3620H,段地址为2000H。n则指令执行后,(IP)=3620H,(CS)=2000H。程序转移到2000H:3620H处继续执行。2段间间接寻址n与段间直接寻址方式相同,转移目标与转移指令不在同一段内,转移指令执行后,CS和IP都发生变化。不同的是转移目标的偏移地址和段地址存储在两个连续的字存储单元中。因此指令中需要用DWORD PTR操作符将存

    7、储单元指定为双字单元。指令执行时,根据存储单元的寻址方式计算出存储单元地址,从该存储单元取第一个字传送到IP,取第二个字传送到CS,这样就可以实现段间转移。例4-4:执行如下指令n JMP DWORD PTR 6BXn假设:(CS)=1000H,(IP)=0600H,(DS)=2000H,(BX)=1000H,(21006H)=3000H,(21008H)=6000H。n则指令执行后,(CS)=6000H,(IP)=3000H。n程序转移到6000H:3000H处继续执行。4.2 无条件转移指令n无条件转移指令JMP使CPU无条件地转移到指令中指明的目的地址处执行。它不能构成分支程序,但在分支

    8、程序中却往往需要用它将各分支的出口重新汇集到一起。特别是当条件转移指令的转移范围超过-128 +127个字节时,往往要借助无条件转移指令实现预定的转移。n转移可分成两类:段内转移和段间转移。段内转移是指在同一代码段内进行转移,此时只需改变IP寄存器的内容,即用新的转移目标地址代替原有的IP值就可达到转移的目的。段间转移则是要转到另一个段去执行程序,此时不仅要修改IP寄存器的内容,还需要修改CS寄存器的内容才能达到目的。因此,此时的转移目标地址应该由新的段地址和偏移地址两部分组成。4.2.1 段内无条件转移1段内直接转移n指令格式:n JMP 标号 ;IP(IP)+位移量n JMP SHORT

    9、标号 ;IP(IP)+8位位移量,短转移n JMP NEAR PTR 标号 ;IP(IP)+16位位移量,近转移n功能:无条件地转移到指令指定的标号处,执行从该标号开始的指令。n其中:JMP为指令操作码。标号为8位或16位偏移量。2段内间接转移n指令格式:JMP 寄存器 JMP WORD PTR 存储单元n功能:程序转移的有效地址放在寄存器或存储单元中,执行指令时,将寄存器或字存储单元中的有效地址写入IP,从而实现转移。4.2.2 段间无条件转移1段间直接转移n指令格式:JMP 标号 JMP FAR PTR 标号n功能:无条件地转移到另一个代码段的标号处,执行从该标号开始的指令。标号所在段的段

    10、地址作为新的CS,标号在该段内的偏移地址作为新的IP。2段间间接转移n指令格式:JMP DWORD PTR 存储单元n功能:指令执行时,从指定存储单元连续取出两个字,第一个字送给IP,第二个字送给CS,从而实现段间转移。nJMP指令不影响状态标志位。4.3 条件转移指令n条件转移指令根据上一条指令所设置的条件标志作判断依据,条件满足则程序转移,否则顺序执行。这类转移指令的转移均属于短转移,即转移目标地址距当前IP所表示的地址的距离为-128 +127字节。n语句格式为:助记符 标号n条件转移指令共有18条,可分成以下三类:n 简单条件转移指令。n 无符号数条件转移指令。n 有符号数条件转移指令

    11、。n条件转移指令均不影响状态标志位。4.3.1 简单条件转移指令n简单条件转移指令共有10条指令。它们是根据5个标志位CF、ZF、SF、OF、PF的两种状态(1或0)而设置的。一般适用于测试某一次运算结果的状态,并根据不同的状态标志产生不同的分支进行处理。n下面分别举例说明。例4-5:假设AX中为一带符号数,求AX中数的绝对值。n分析:求一个数的绝对值时,首先要测试该数的正负。我们可以测试其最高位,也可以测试符号标志。因此以下两个程序段均可求出AX中数的绝对值。n程序段1:TEST AX,8000H JZ NEXT ;测试AX最高位,为零该数为正,转到NEXT NEG AX ;否则,AX为负,

    12、求补运算 NEXT:n程序段2:AND AX,AX ;影响标志位 JNS NEXT ;测试AX的符号位,为正则转到NEXT NEG AX ;否则,AX为负,求补运算 NEXT:例4-6:计算X+Y,X和Y单元分别存放着一个16位有符号数。若结果有溢出,则转移到OVERFLOW处理。n分析:两个有符号数相加,影响OF的值。若OF置1,则产生溢出。n程序段如下:MOV AX,X ADD AX,Y JO OVERFLOW ;没有溢出,结果正确nOVERFLOW:;溢出处理例4-7:统计寄存器BX中1的个数。n分析:要统计寄存器BX中1的个数,可以通过移位指令将BX中的每一位依次移入CF中,若CF=1

    13、则CL的值加1。这样就可以统计出BX中1的个数。n程序段如下:MOV CL,0;保存BX中1的个数,初值为0 AGAIN:AND BX,BX JZ EXIT,(BX)=0时,结束循环转EXIT SAL BX,1 ;将BX中的最高位移入CF中 JNC AGAIN ;如果CF=0转AGAIN INC CL ;否则,CL的值加1 JMP AGAIN ;转AGAIN处继续处理 EXIT:4.3.2 无符号数条件转移指令n这类指令往往跟在比较指令之后,视比较对象为无符号数。根据比较结果的不同状态,设置了高于(A-Above)、高于或等于(AE-Above or Equal)、低于(B-Below)、低于

    14、或等于(BE-Below or Equal)四条指令。无符号数条件转移指令n JA/JNBE 用于两个无符号数a、b的比较,若ab则条件满足,实现转移。n JNA/JBE 用于两个无符号数a、b的比较,若ab则条件满足,实现转移。n JB/JNAE 用于两个无符号数a、b的比较,若ab则条件满足,实现转移。n JNB/JAE 用于两个无符号数a、b的比较,若ab则条件满足,实现转移。n四条指令的共同点是根据两个无符号数比较的结果,判断CF、ZF的状态是否满足转移条件,当满足条件时转移,否则顺序执行。适用于地址比较、循环次数比较或双精度数的低位字的比较等。例4-8:阅读下面程序段,若寄存器AL的

    15、值分别取20H、5、0FFH和2,分析程序段的执行情况。n程序段如下:CMP AL,5 JA NEXT ADD AL,5 NEXT:n分析:本程序段使用了无符号数跳转指令JA,若(AL)5则转NEXT,否则顺序执行。n(1)(AL)=20H5,满足条件,跳至NEXT处执行。n(2)(AL)=5,不满足条件,顺序执行“ADD AL,5”。n(3)(AL)=0FFH,由于JA是无符号数跳转指令,对无符号数来说(AL)=0FFH5,满足转移条件,故跳转至NEXT处执行。n(4)(AL)=25,不满足条件,故顺序执行后继指令。例4-9:分析以下程序段:n MOV SI,0 ;SI0nJP:MOV WO

    16、RD PTR SI,0 ;SI 0n ADD SI,2 ;SI(SI)+2n CMP SI,0F000H ;判断(SI)是否小于等 于0F000Hn JNA JP ;若小于等于,则转JP执行n n分析:该程序段的功能是将当前数据段中偏移地址为0 0F000H的全部字存储单元清0,其中SI为送数指针。n注意:在比较判断(SI)是否小于等于0F000H时,由于地址是无符号数,所以必须选用无符号数条件转移指令JNA,才能完成预定功能。4.3.3 带符号数条件转移指令n在程序设计中,有时需要把处理对象视为带符号数(补码表示)。当比较两个带符号数的大小时,要选用带符号数条件转移指令。带符号数条件转移指令

    17、是根据条件标志ZF、SF、OF的特定组合来决定是否转移,共设置了大于、大于或等于、小于、小于或等于四条指令。带符号数条件转移指令n JG/JNLE 用于两个有符号数a、b比较。若ab,即符号标志SF与溢出标志OF具有相同状态(SF=OF)且零标志ZF=0时,条件满足,实现转移。n JNG/JLE 用于两个有符号数a、b的比较。若ab,即当SFOF或ZF=1时,条件满足,实现转移。n JL/JNGE 用于两个有符号数a、b的比较。若ab,即当SFOF时,条件满足,实现转移。n JNL/JGE 用于两个有符号数a、b的比较。若ab,即当SF=OF时,条件满足,实现转移。n四条指令的共同点是根据两个

    18、带符号数比较运算的结果,组合SF、OF标志,并利用ZF标志确定转移与否。n下面举例说明条件转移指令的使用方法。例4-10:假设有两个双精度数a和b,分别存储在AX、BX和CX、DX中,分析下列程序段的功能。n程序段如下:CMP AX,CX JG UPPER JL LOWER CMP BX,DX JA UPPER LOWER:UPPER:图4-4 比较两个数大小算法流程图(AX)(CX)(AX)(DX)NNNYYY标号UPPER处标号LOWER处n分析:本程序段的功能是比较两个双精度数a和b的大小,若ab则转向UPPER执行,否则转向LOWER执行。程序段流程图如图4-4所示。例4-11:将例4

    19、-9程序段中的JNA指令改成JNG指令,分析程序段功能。n程序段如下:MOV SI,0 ;SI0 JP:MOV WORD PTR SI,0 ;SI 0 ADD SI,2 ;SI(SI)+2 CMP SI,0F000H ;判断(SI)是否小于等于0F000H JNG JP ;若小于等于,则转JP执行 分析:n该程序段在进行比较判断时,选用了带符号数条件转移指令JNG。在第一次执行比较指令“CMP SI,0F000H ”时,(SI)=2,它与带符号数0F000H(即1000H)比较,显然21000H,不满足“JNG”的转移条件而顺序执行后继语句。这样就只能将0送入偏移地址为0的字单元中,无法实现将

    20、当前数据段中偏移地址为0 0F000H的全部字存储单元清0。n以上例子说明在设计分支程序时一定要注意正确选择条件转移指令。4.4 分支程序设计方法n在实际应用中,计算机处理的问题不可能全是顺序地执行操作,而往往需要对出现的各种情况进行分析判断,以决定进行不同的处理。这种分不同情况进行不同处理的程序结构就是分支程序结构。n分支程序结构有两种形式,如图4-5所示:图4-5 分支程序结构示意图图(a)二分支结构判定条件为真NY分支1分支2图(b)多分支结构判定条件条件1分支2分支1分支n条件2条件nn不论哪一种形式,它们的共同特点是:运行方向是向前的,在某一种确定条件下,只能执行多个分支中的一个分支

    21、。4.4.1 二分支程序设计n所谓二分支程序设计,就是根据判定条件为真或为假,从两条分支中选择一条分支去执行。二分支程序中的一种特殊情况就是只有一个分支程序段,另一个分支是顺序执行,有时也把这种结构称为单分支结构。例4-12:分析下列程序段的结构。n CMP AX,0 n JGE DONE ;如果(AX)0,则转DONEn NEG AX ;否则进行求补运算nDONE:MOV RESULT,AX ;保存结果 n 图4-6 单分支程序结构示意图(AX)0为真YYAX(AX)RESULT(AX)Nn 本程序段用来计算AX中带符号数的绝对值,是一个典型的单分支结构。程序段流程图如图4-6所示:n要设计

    22、双分支程序结构,首先要产生条件,然后对产生的条件进行分析判断,根据判断结果决定执行哪一个分支,最后转入相应程序段的起始地址去执行分支程序。其中产生条件的指令通常由指令系统中影响状态标志位的指令来产生,如算术运算指令(如ADD、SUB、CMP)、逻辑运算指令(如AND、TEST)、移位指令(如SHR、SHL)等等。要想用好这些指令,就要搞清楚这些指令的功能及其对标志位的影响。特别是要熟练掌握状态标志位CF、ZF、PF、SF和OF的含义。n下面我们通过例子来介绍二分支程序设计方法。例4-13:从键盘输入0 9中任一自然数x,求其立方值。若输入的字符不是0 9中的某数字,则显示“INPUT ERRO

    23、R!”,表明输入错误。n分析:求一个数的立方值可以用乘法运算实现,也可以构造一立方表,通过查表实现。此处用查表法,查表法执行速度比较快。n输入数据为0至9中任一自然数,用一字节单元存放其值;输出数据是该数的立方值,用一字单元存放其值。若输入时不慎按下0 9之外的字符键,则显示错误提示信息。n存储单元和寄存器分配如下:n字节变量X中存放键入的自然数x。n字变量Y中存放x的立方值。nAX是用来存放立方值的工作单元。nBX是用来进行查表的工作单元。图4-8 求立方值程序流程图(AL)是09中某一数字符Y将字符ASCII码转换成数字真值Y求立方值N开始结束AL从键盘输入字符显示错误提示信息n假定立方表

    24、的首地址为TAB,表中共10项,每项占一个字,用来存放x的立方值。从表的结构可知,x的立方值在表中的存放地址与x有如下对应关系:(TAB+2*x)=x的立方值对于每个键入的x,从字单元TAB+2*x中取出的数据便是其立方值。n从键盘接受数字输入使用1号系统功能调用,此时送入AL中的是x的ASCII码,而不是x的真值。所以要首先将x的ASCII 码转换成x的真值,然后用TAB+2*x计算x立方值的存放地址,按此地址查到x的立方值。n程序流程图如图4-8所示:源程序如下:nSTACK SEGMENT STACKn DB 200 DUP(0)nSTACK ENDSnDATA SEGMENTnINPU

    25、T DB PLEASE INPUT X(0.9):$nTAB DW 0,1,8,27,64,125,216,343,512,729nX DB?nY DW?nINERR DB 0DH,0AH,INPUT ERROR !$nDATA ENDSnCODE SEGMENTn ASSUME CS:CODE,DS:DATA,SS:STACKnBEGIN:MOV AX,DATAn MOV DS,AXn LEA DX,INPUTn MOV AH,9n INT 21H ;9号调用显示提示信息n MOV AH,1n INT 21H ;AL1号调用从键盘接受一字符输入 n CMP AL,0;若输入字符不是09中的某

    26、一数字,转LERRn JB LERRn CMP AL,9n JA LERRn AND AL,0FHn MOV X,AL ;Xx的真值n ADD AL,ALn MOV BL,AL ;BX2xn MOV BH,0n MOV AX,TABBXn MOV Y,AX ;Yx的立方值nEXIT:MOV AH,4CHn INT 21H ;结束程序,返回DOS状态nLERR:MOV DX,OFFSET INERRn MOV AH,9 ;显示错误提示信息n INT 21Hn JMP EXITnCODE ENDSn END BEGINn程序运行时,屏幕首先显示“PLEASE INPUT X(0.9):”,若键入

    27、2,则2*x=4,4BX,从字单元TAB+4中取出2的立方值8送入Y中。若键入字符a,因其不是09中的某一数字符,故显示“INPUT ERROR!”。例4-14:将a、b、c三个十六位无符号数分别与零比较,如果三个数均不为零,求出三个数之和存放在变量d中(假设总和小于65535),若其中至少有一个数为零,则显示“ERROR!”。n分析:本题目的程序结构属于双分支结构的嵌套形式,对标志位的判断需要进行两次以上,才能确定其分支。n程序流程图如图4-9所示。n存储单元和寄存器分配如下:n字变量A、B、C用来存放三个十六位无符号数;n变量D用来存放三个数的和;nAX是用来求和的工作单元。图4-9 求三

    28、个数和的程序流程图A=0YD求三数和N开始结束显示”ERROR!”B=0C=0NNYY源程序如下:nSTACK SEGMENT STACKn DB 200 DUP(0)nSTACK ENDSnDATA SEGMENTnA DW 1234HnB DW 5678HnC DW 3562HnD DW?nINERR DB 0DH,0AH,ERROR !$nDATA ENDSnCODE SEGMENTn ASSUME CS:CODE,DS:DATA,SS:STACKnBEGIN:MOV AX,DATAn MOV DS,AXn MOV AX,0 ;AX清0n CMP A,0n JZ NEXT ;a=0,转N

    29、EXTn CMP B,0n JZ NEXT ;b=0,转NEXT n CMP C,0n JZ NEXT ;c=0,转NEXTn ADD AX,An ADD AX,Bn ADD AX,Cn MOV D,AX ;三数求和,结果存入D中n JMP EXITnNEXT:MOV DX,OFFSET INERRn MOV AH,9n INT 21HnEXIT:MOV AH,4CHn INT 21H ;结束程序,返回DOS状态nCODE ENDSn END BEGINn本程序运行时,由于A、B、C三个数均不为零,故求出三个数之和9E0EH存放在变量D中。读者可任意修改A、B、C三个变量的值,比较其运行结果。

    30、例4-16:假设有三个单字节无符号数依次存放在BUF1开始的存储区中,试编写程序将它们从大到小排列并依次存放在BUF2开始的存储区中。分析(方法一)将三个无符号数依次送入AL、BL、CL三个工作单元中,然后在三个工作单元之间比较大小,排好顺序后依次存放在BUF2开始的存储区中。n程序流程图如图4-11所示:n存储单元和寄存器分配如下:nBUF1用来保存原始数据的存储区首址;nBUF2用来存放已排序数据的存储区首址;nAL、BL、CL用来存放原始数据的工作单元;nSI用来指向BUF1的工作指针nDI用来指向BUF2的工作指针。图4-11 将三个数由大到小排列程序流程图(AL)(BL)YN开始结束

    31、NYAL、BL、CLNN将三个数分别送到AL、BL、CL中(BL)(CL)(BL)(CL)(AL)(CL)(AL)(CL)AL、CL、BLCL、AL、BLCL、BL、ALBL、AL、CLBL、CL、ALYYYN源程序如下:STACK SEGMENT STACK DB 200 DUP(0)STACK ENDSDATA SEGMENTBUF1 DB 56H,12H,78HBUF2 DB 3 DUP(0)DATA ENDSCODE SEGMENT ASSUME CS:CODE,DS:DATA,SS:STACKBEGIN:MOV AX,DATA MOV DS,AX MOV SI,OFFSET BUF1

    32、 ;SI指向BUF1存储区 MOV DI,OFFSET BUF2 ;DI指向BUF2存储区 MOV AL,SI MOV BL,SI+1 ;将原始数据分别送入AL、BL、CL MOV CL,SI+2 CMP AL,BL JAE NEXT1 CMP BL,CLn JAE NEXT3n MOV DI,CLn MOV DI+1,BLn MOV DI+2,ALn JMP EXITnNEXT1:CMP BL,CLn JAE NEXT2n CMP AL,CLn JAE NEXT21n MOV DI,CLn MOV DI+1,ALn MOV DI+2,BLn JMP EXITNEXT2:MOV DI,ALn

    33、MOV DI+1,BLn MOV DI+2,CLn JMP EXITnNEXT21:MOV DI,ALn MOV DI+1,CLn MOV DI+2,BLn JMP EXITnNEXT3:CMP AL,CLn JAE NEXT31n MOV DI,BLn MOV DI+1,CLn MOV DI+2,ALn JMP EXITnNEXT31:MOV DI,BLn MOV DI+1,ALn MOV DI+2,CLn EXIT:MOV AH,4CHn INT 21H nCODE ENDSn END BEGINn程序运行后,BUF2存储区中依次存储 78H 56H 12H。n由图4-11可以看到,用此种

    34、方法来比较三个数的大小是非常麻烦的,编程工作量很大。下面我们再来介绍一种简单方法。(方法二):n首先将三个无符号数依次送入AL、BL、CL三个工作单元中,然后比较AL和BL,若AL小于BL,则将两者内容交换;再比较AL和CL,若AL小于CL,将两者内容交换,这样AL中保存的就是三个数中的最大者。再比较BL与CL,若BL小于CL,就将两者内容交换,即将最小的数放在CL中。最终将三个数按由大到小的顺序依次存放在AL、BL和CL中。n程序流程图如图4-12所示:n存储单元和寄存器分配同方法一。n源程序如下:Y开始结束N将三个数分别送到AL、BL、CL中图4-12 将三个数由大到小排列程序流程图(AL

    35、)(BL)(AL)和(BL)交换(AL)(CL)按AL、BL、CL顺序依次存回N(AL)和(CL)交换N(BL)和(CL)交换(BL)(CL)YYnSTACK SEGMENT STACKn DB 200 DUP(0)nSTACK ENDSnDATA SEGMENTnBUF1 DB 56H,12H,78HnBUF2 DB 3 DUP(0)nDATA ENDSnCODE SEGMENTn ASSUME CS:CODE,DS:DATA,SS:STACKnBEGIN:MOV AX,DATAn MOV DS,AXn MOV SI,OFFSET BUF1n MOV DI,OFFSET BUF2n MOV

    36、AL,SIn MOV BL,SI+1n MOV CL,SI+2n CMP AL,BLn JAE NEXT1n XCHG AL,BLnNEXT1:CMP AL,CLn JAE NEXT2n XCHG AL,CLnNEXT2:CMP BL,CLn JAE NEXT3n XCHG BL,CLnNEXT3:MOV DI,ALn MOV DI+1,BLn MOV DI+2,CLn MOV AH,4CHn INT 21HnCODE ENDSn END BEGINn读者可对照流程图自己分析源程序。显然第二种方法比较次数更少,编程工作量也大大减少。4.4.2 多分支程序设计n在实际应用中,有时会碰到多分支程序

    37、结构。多分支程序结构相当于一个多路开关,有多个并行的分支程序段,每个分支程序段与一个条件相对应,执行时只能执行其中一个分支段。若用条件转移语句实现,则N条分支需要N-1个条件转移指令完成,转移速度慢,程序代码长。因此常采用地址表法来实现。n地址表法的设计思想是:在程序段中开辟一些存储空间,形成一张地址表,用于依次存放各分支程序段的程序入口地址。程序执行时,首先判断出满足某分支程序段的条件,由此求出该分支程序段的编号。该编号乘2(段内转移),或乘4(段间转移)得到相对地址表的偏移量,再加上地址表首地址,即得到地址表中的一个地址。在这个地址表地址中存放着分支程序段的偏移地址(或偏移地址+段地址),

    38、转到该地址去执行程序,即执行该分支程序段。例4-17:设计一个程序,根据键盘输入的1 9数字转向9个不同的处理程序段。n分析:在数据段定义一个存储区,形成一地址表,用来存放9个处理程序段的起始地址。将键盘输入的1 9数字符转换为真值,用于查表得到偏移地址。若输入非法字符则提示出错。n程序流程图如图4-13所示:n源程序如下:nSTACK SEGMENT STACKn DB 200 DUP(0)nSTACK ENDS图4-13 多分支结构程序流程图是数字字符?1计算转移地址,转向P02计算转移地址,转向P01计算转移地址,转向P0929Y开始结束显示错误提示信息AL从键盘输入一个字符数字=?Nn

    39、CODE SEGMENTn ASSUME CS:CODE,DS:DATA,SS:STACKnBEGIN:MOV AX,DATAn MOV DS,AXn LEA DX,INPUTn MOV AH,9n INT 21H ;9号调用显示提示信息n MOV AH,1n INT 21H ;1号调用从键盘接受一字符输入n CMP AL,1 ;若输入字符不是19中的某一数字,转LERR JB LERRn CMP AL,9n JA LERR n AND AX,000FH ;将ASCII码转换成数字n DEC AXn ADD AX,AXn MOV BX,AXn JMP TABBX ;查表,段内间接转移n EXIT:MOV AH,4CHn INT 21Hn LERR:MOV DX,OFFSET INERRn MOV AH,9n INT 21Hn JMP EXITnP01:;各处理程序入口n P02:n n P09:nCODE ENDSn END BEGIN本章小结n本章主要介绍了与转移有关的寻址方式、转移指令,以及分支程序设计的基本思想和设计方法。通过本章的学习,一定要熟练掌握无条件转移指令和条件转移指令,正确理解转移指令的功能和使用条件,分清无符号数的条件转移指令和带符号数的条件转移指令的区别,熟练掌握分支程序设计。

    展开阅读全文
    提示  163文库所有资源均是用户自行上传分享,仅供网友学习交流,未经上传用户书面授权,请勿作他用。
    关于本文
    本文标题:《汇编语言程序设计》-相伟-电子教案第4章课件.ppt
    链接地址:https://www.163wenku.com/p-4145463.html

    Copyright@ 2017-2037 Www.163WenKu.Com  网站版权所有  |  资源地图   
    IPC备案号:蜀ICP备2021032737号  | 川公网安备 51099002000191号


    侵权投诉QQ:3464097650  资料上传QQ:3464097650
       


    【声明】本站为“文档C2C交易模式”,即用户上传的文档直接卖给(下载)用户,本站只是网络空间服务平台,本站所有原创文档下载所得归上传人所有,如您发现上传作品侵犯了您的版权,请立刻联系我们并提供证据,我们将在3个工作日内予以改正。

    163文库