循环与分支设计.ppt
《循环与分支设计.ppt》由会员分享,可在线阅读,更多相关《循环与分支设计.ppt(53页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、第五章第五章 循环与分支程序设计循环与分支程序设计5.1 循环与转移指令循环与转移指令5.2 循环程序设计循环程序设计5.3 分支程序设计分支程序设计1编写汇编语言程序步骤1 分析题意,确定算法分析题意,确定算法2 根据算法,画出程序流程图根据算法,画出程序流程图3 根据框图编写程序根据框图编写程序4 上机调试程序上机调试程序25.1 循环与转移指令循环与转移指令一、循环控制指令一、循环控制指令二、转移指令二、转移指令 控控制制转转移移类类指指令令通通过过改改变变IP(和和CS)值值,实现程序执行顺序的改变实现程序执行顺序的改变3一、循环控制指令一、循环控制指令w8086指令系统的循环控制指令
2、均为二字节指令系统的循环控制指令均为二字节指令指令n一字节为转移的相对位移量(一字节为转移的相对位移量(8位带符号的二位带符号的二进制数)进制数)IP IP+相对位移量相对位移量n隐含使用隐含使用CX作为循环计数器作为循环计数器程程序序中中的的某某段段需需反反复复执执行行若若干干次次时时,用用循环来实现循环来实现小范围转移小范围转移4一、循环控制指令一、循环控制指令LOOP label;CXCX1,CX0,循环到标号循环到标号labelLOOPE/LOOPZ label;CXCX1,CX0 且且ZF1,循环到标号循环到标号labelLOOPNE/NZ label;CXCX1,CX0且且ZF0,
3、循环到标号循环到标号label等于时循环等于时循环不等于时循环不等于时循环5一、循环控制指令一、循环控制指令(例)(例)mov cx,countmov cx,count;设置循环次数设置循环次数mov si,offset stringmov si,offset stringxor bx,bxxor bx,bx;bxbx清清0 0,用于记录空格数,用于记录空格数mov al,20hmov al,20hagain:again:cmp al,sicmp al,sijnz nextjnz next;ZF=0ZF=0,非空格,转移非空格,转移inc bxinc bx;ZF=1ZF=1,是空格,个数加是空
4、格,个数加1 1next:next:inc siinc siloop againloop again;计数器减计数器减1 1,不为,不为0 0继续循环继续循环dec cxjnz again6二、转移指令二、转移指令1.无条件转移指令无条件转移指令2.条件转移指令条件转移指令71.无条件转移指令无条件转移指令JMP labelJMP label;程序转向程序转向labellabel标号指定的地址标号指定的地址NEARFARw只要执行无条件转移指令只要执行无条件转移指令JMP,就使程序转到指定就使程序转到指定的目标地址处,从目标地址处开始执行那里的指令的目标地址处,从目标地址处开始执行那里的指令w
5、JMP指令分成指令分成4种类型:种类型:段内转移、直接寻址段内转移、直接寻址 段内转移、间接寻址段内转移、间接寻址 段间转移、直接寻址段间转移、直接寻址 段间转移、间接寻址段间转移、间接寻址目的地址与目的地址与JMP属同一属同一逻辑段,只修改逻辑段,只修改IP值值从一个代码段转移到另一个代从一个代码段转移到另一个代码段,码段,CS和和IP都会被修改都会被修改81.无条件转移指令无条件转移指令目标地址的寻址方式目标地址的寻址方式w直接寻址方式直接寻址方式n转移地址象立即数一样,直接在指令的转移地址象立即数一样,直接在指令的机器代码中,就是直接寻址方式机器代码中,就是直接寻址方式w间接寻址方式间接
6、寻址方式n转移地址在寄存器或主存单元中,就是转移地址在寄存器或主存单元中,就是通过寄存器或存储器的间接寻址方式通过寄存器或存储器的间接寻址方式用标号表达用标号表达用寄存器或存储用寄存器或存储器操作数表达器操作数表达91.无条件转移指令无条件转移指令目标地址的范围:段内目标地址的范围:段内w段内转移段内转移近转移(近转移(near)n在当前代码段在当前代码段64KB范围内转移(范围内转移(32KB范围)范围)n不需要更改不需要更改CS段段基值基值,只要改变,只要改变IP偏移地址偏移地址w段内转移段内转移短转移(短转移(short)n转移范围可以用一个字节表达,转移范围可以用一个字节表达,在段内在
7、段内128127范围的转移范围的转移代代码码段段代代码码段段101.无条件转移指令无条件转移指令目标地址的范围:段间目标地址的范围:段间w段间转移段间转移远转移远转移(far)n从当前代码段跳转到另一个从当前代码段跳转到另一个代码段,可以在代码段,可以在1MB范围范围n需要更改需要更改CS段段基值基值和和IP偏移偏移地址地址n目标地址必须用一个目标地址必须用一个32位数位数表达,叫做表达,叫做32位远指针,它位远指针,它就是逻辑地址就是逻辑地址代代码码段段代代码码段段 实实际际编编程程时时,汇汇编编程程序序会会根根据据目目标标地地址址的的距距离离,自动处理成短转移、近转移或远转移自动处理成短转
8、移、近转移或远转移 程序员可用操作符程序员可用操作符short、near ptr 或或far ptr 强制强制11段内直接寻址转移段内直接寻址转移JMP labelJMP label;IPIP+IPIP+位移量位移量w位移量是紧接着位移量是紧接着JMP指令后的那条指令的偏移地址指令后的那条指令的偏移地址到目标指令的偏移地址的地址差到目标指令的偏移地址的地址差w当向地址增大方向转移时,位移量为正;向地址减当向地址增大方向转移时,位移量为正;向地址减小方向转移时,位移量为负小方向转移时,位移量为负实际为相对寻址实际为相对寻址again:again:dec cxdec cx;标号标号againaga
9、in的指令的指令 jmp again jmp again ;转移到转移到againagain处继续执行处继续执行jmp outputjmp output;转向转向outputoutputoutput:output:mov result,almov result,al;标号标号outputoutput的指令的指令12段内间接寻址转移段内间接寻址转移JMP r16/m16JMP r16/m16 ;IPr16/m16IPr16/m16w将一个将一个1616位寄存器或主存字单元内容送入位寄存器或主存字单元内容送入IPIP寄存器,作为新的指令指针,但不修改寄存器,作为新的指令指针,但不修改CSCS寄存器
10、的内容寄存器的内容jmp axjmp ax;IPAXIPAXjmp word ptr bxjmp word ptr bx;IPBXIPBX13段间直接寻址转移段间直接寻址转移JMP far ptr labelJMP far ptr label;IPlabelIPlabel的偏移地址的偏移地址;CSlabelCSlabel的段基值的段基值w将标号所在段的段将标号所在段的段基值基值作为新的作为新的CS值,标值,标号在该段内的偏移地址作为新的号在该段内的偏移地址作为新的IP值;程值;程序跳转到新的代码段执行序跳转到新的代码段执行jmp far ptr othersegjmp far ptr othe
11、rseg;远转移到代码段远转移到代码段2 2的的othersegotherseg14段间间接寻址转移段间间接寻址转移JMP far ptr memJMP far ptr mem;IPmemIPmem,CSmem+2CSmem+2w用一个双字存储单元表示要跳转的目标地址。用一个双字存储单元表示要跳转的目标地址。这个目标地址存放在主存中连续的两个字单元这个目标地址存放在主存中连续的两个字单元中的,低位字送中的,低位字送IPIP寄存器,高位字送寄存器,高位字送CSCS寄存器寄存器mov word ptr bx,0mov word ptr bx,0mov word ptr bx+2,1500hmov
12、word ptr bx+2,1500hJMP far ptr bxJMP far ptr bx ;转移到转移到15001500h:0h:0152.条件转移指令条件转移指令Jcc labelJcc label ;条件满足,发生转移:条件满足,发生转移:IPIPIPIP8 8位位移量位位移量 ;条件不满足,顺序执行;条件不满足,顺序执行指指定定的的条条件件cc如如果果成成立立,程程序序转转移移到到由由标标号号label指指定定的的目目标标地地址址去去执执行行指指令令;条条件件不成立,则程序将顺序执行下一条指令不成立,则程序将顺序执行下一条指令操操作作数数label是是采采用用短短转转移移,称称为为
13、相相对对寻寻址址方式方式162.条件转移指令条件转移指令wJcc指令的操作数指令的操作数label是一个标号是一个标号n一个一个8位位移量是相对于当前位位移量是相对于当前IP的,且距当前的,且距当前IP地址地址128127个单元的范围之内,属个单元的范围之内,属于段内短距离转移于段内短距离转移wJcc指令为指令为2个字节,条件不满足时的顺序个字节,条件不满足时的顺序执行就是当前指令偏移指针执行就是当前指令偏移指针IP加加2172.条件转移指令条件转移指令指令的分类指令的分类wJcc指令不影响标志,但要利用标志。指令不影响标志,但要利用标志。w根据利用的标志位不同,根据利用的标志位不同,19条指
14、令分条指令分成成4种情况:种情况:判断单个标志位状态判断单个标志位状态 比较无符号数高低比较无符号数高低 比较有符号数大小比较有符号数大小 判断计数器判断计数器CX为为0182.条件转移指令条件转移指令无符号数的比较无符号数的比较无符号数的大小用高(无符号数的大小用高(Above)低(低(Below)表表示示利用利用CF确定高低、利用确定高低、利用ZF标志确定相等标志确定相等(Equal)两数的高低分成两数的高低分成4种关系:种关系:高于(不低于等于):高于(不低于等于):JA(JNBE)高于等于(不低于):高于等于(不低于):JAE(JNB)低于(不高于等于):低于(不高于等于):JB(JN
15、AE)低于等于(不高于):低于等于(不高于):JBE(JNA)192.条件转移指令条件转移指令有符号数的比较有符号数的比较w有符号数的大(有符号数的大(Greater)小(小(Less)需要需要组合组合OF、SF标志,并利用标志,并利用ZF标志确定相标志确定相等(等(Equal)w两数的大小分成两数的大小分成4种关系:种关系:小于(不大于等于):小于(不大于等于):JL(JNGE)小于等于(不大于):小于等于(不大于):JLE(JNG)大于(不小于等于):大于(不小于等于):JG(JNLE)大于等于(不小于):大于等于(不小于):JGE(JNL)20助记符助记符标志位标志位助记符助记符标志位标
16、志位JCCF=1JA/JNBECF=0且且ZF=0JNCCF=0JAE/JNBCF=0或或ZF=1JZ/JEZF=1JB/JNAECF=1且且ZF=0JNZ/JNEZF=0JBE/JNACF=1或或ZF=1JSSF=1JG/JNLESF=OF且且ZF=0JNSSF=0JGE/JNLSF=OF或或ZF=1JP/JPEPF=1JL/JNGESFOF且且ZF=0JNP/JPOPF=0JLE/JNGSFOF或或ZF=1JOOF=1JCXZCX=0JNOOF=0 实际虽然指令只有实际虽然指令只有19条,但却有条,但却有31个助记符个助记符 采用多个助记符,只是为了方便记忆和使用采用多个助记符,只是为了方
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 循环 分支 设计
限制150内