汇编语言课件10顺序、分支、循环程序.pptVIP

汇编语言课件10顺序、分支、循环程序.ppt

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
汇编语言课件10顺序、分支、循环程序.ppt

汇编语言课件10 顺序、分支、循环程序 程序设计步骤 分析问题 建立数学模型 选择算法和数据结构 详细设计:模块功能、流程图 编写程序、调试程序、分析结果 程序结构 顺序 分支 循环 顺序程序设计 没有分支、循环等转移指令的程序,按指令书写的前后顺利依次执行,这就是顺序程序 .model small .stack .data array dw 1,2,4,8,16,32,64,128,256 dw 512,1024,2048,4096,8192,16384 x db 11 ;待查数据,例子查211 pwr dw ? ;存结果 .code .startup mov bh,0 mov bl,x shl bx,1 mov ax,array[bx] mov pwr,ax .exit 0 end .model small .stack .data array dw 1,2,4,8,16,32,64,128,256,512 ;x db 11 ;待查数据,例子查211 pwr dw ? ;存结果 .code .startup mov ah,1 ;1号功能,读取一个字符至al int 21h sub al,’0’ mov bh,0 mov bl,al ;原为:mov bl,x shl bx,1 mov ax,array[bx] mov pwr,ax .exit 0 end 分支程序设计 汇编语言中,使用条件转移JXX指令和无条件转移JMP指令实现分支程序结构 条件转移指令判断的条件是标志位。因此,需要在条件转移指令前安排算术运算、比较、测试等影响相应标志位的指令。 转移指令 无条件转移指令 直接改变CS和(或)IP中的内容 条件转移指令 条件满足,改变IP中的内容 条件不满足,顺序执行下一条指令 无条件转移指令 基本格式:JMP 标号 1.段内转移 只修改IP中的内容,不涉及改变CS中的内容 采用相对寻址/间接寻址 (1)段内直接短转移 格式 JMP SHORT  标号  双字节指令  操作:IP←(IP)+DISP8 例:jmp SHORT tag1 (2)段内直接近转移 格式 JMP [NEAR PTR] 标号  三字节指令  操作:IP←(IP)+DISP16 例:jmp NEAR PTR tag2 (3)段内间接转移 格式 JMP r16/m16  采用间接寻址  操作:IP←(r16/m16 ) 例:jmp bx jmp WORD PTR [SI] 2. 段间转移 需要修改IP和CS中的内容 采用直接寻址/间接寻址 (1)段间直接转移 采用直接寻址 指令格式:JMP FAR PTR 标号 操作: IP←标号的段内偏移量属性 CS←标号的段基址属性 例:jmp FAR PTR tag3 FAR PTR常常省去 (2)段间间接转移 采用间接寻址方式 指令格式: JMP FAR(DWORD) PTR mem 指令操作:IP←[mem], CS←[mem+2] 例:jmp far ptr jtable[bx] 条件转移指令 条件转移指令JXX根据指定的条件确定程序是否发生转移。如果满足条件,则程序转移到目的地址去执行程序;不满足条件,则程序将顺序执行下一条指令。 JXX label ;条件满足,发生转移:IP←IP+8位位移量; ;否则,顺序执行 1. 判断单个标志位状态 JZ(JE)和JNZ(JNE)利用零标志ZF,分别判断结果是零(相等)还是非零(不等) JS和JNS利用符号标志SF,分别判断结果是负还是正 JO和JNO利用溢出标志OF,分别判断结果是溢出还是没有溢出 JP(JPE)和JNP(JPO)利用奇偶标志PF,判断结果中“1”的个数是偶数还是奇数 JC和JNC,利用进位标志CF,判断结果是有进位(为 1)还是无进位(为0) JCXZ,CX寄存器为0转 例 将AX中存放的无符号数除以2,如果是奇数则加1后除以2 test ax,1 ;测试AX的最低位D0 jz even ; 即D0=0, AX内是偶数,程序转移 add ax,1 ; 即D0=1:AX内的奇数加1 even: shr ax,1 ; AX←AX÷2 例 寄存器AL中是字母Y(大/小写),则令AH=0,否则令AH=-1 cmp al, ‘y’ ;比较AL与小写字母y

文档评论(0)

sunguohong + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档