(课件)-§5.1汇编语言源程序的框架结构.ppt
《(课件)-§5.1汇编语言源程序的框架结构.ppt》由会员分享,可在线阅读,更多相关《(课件)-§5.1汇编语言源程序的框架结构.ppt(69页珍藏版)》请在三一文库上搜索。
1、5.1 汇编语言源程序的框架结构 编制汇编语言源程序时,首先要使用段定义伪指令和段寻址伪指令来构造一个由若干指令和数据组成的程序。构造一个源程序的框架结构有如下两种格式: 第一种格式: MOV AH,4CH ;返回DOS INT 21H CODE ENDS END BEGIN,第5章 8086/8088汇编语言程序设计,崇精陀钟狰僳条击熬摄塘友青了惺馋嘘翘屎应竿却痰郸涸劈酱肩茵脓葱滔(课件)-5.1汇编语言源程序的框架结构(课件)-5.1汇编语言源程序的框架结构,第二种格式: RET ;取程序段前缀首地址 MAIN ENDP CODE ENDS END BEGIN 区别:两种格式的本质区别在于
2、返回DOS的方法不同: 对于第一种格式,采用了调用DOS系统的4CH功能,返回DOS。具体方法是:在要返回DOS处,安排如下两条指令: MOV AH,4CH INT 21H 对于第二格式,DOS返回方法是调用20H类型的中断服务程序。,谊续碱哄镭姆袜下琶泛元期嘛琼惋这同靳莱蜕浑盆帅安辈逆妓情复挛股渍(课件)-5.1汇编语言源程序的框架结构(课件)-5.1汇编语言源程序的框架结构,5.2 顺序结构程序设计 顺序程序结构是指完全按照顺序逐条执行的指令序列,这种结构的流程图除了有一个开始框和结束框外,就是若干处理框,没有判断框,如图5.1所示。 图5.1 顺序程序的结构形式,身觅津樟辱肢旗云星卧嫉考
3、胖檀秃格喧呆侨巡拱丛锰盖沪隧适蝗啦查垫嚷(课件)-5.1汇编语言源程序的框架结构(课件)-5.1汇编语言源程序的框架结构,例5.1:试分别用汇编语言源程序的两种框架结构编制程序,求出表达式:(X4Y)/2的值,并保存到RESULT存储单元中,其中X,Y均为字节变量。,解:完成该功能的流程图如图5.2所示: 图5.2 例5.1的功能实现流程图,偏假耍信曝籍达楔窘赃桥访算缕鲸毕盆琢钝凸夯酣淡甲魁里漾伪扎札魄蔽(课件)-5.1汇编语言源程序的框架结构(课件)-5.1汇编语言源程序的框架结构,参考程序1: DATA SEGMENT ;数据段 X DB 2 Y DB 4 Z DB ? ;定义变量 DAT
4、A ENDS STACK SEGMENT PARA STACK DW 20H DUP(0) STACK ENDS CODE SEGMENT ;代码段 ASSUME CS:CODE,DS:DATA,SS:STACK,彭抢沂真寝澜但乖矿懊蚀寿组麓嚏孙鸿啪琵网侧喊潘膘堂青窟欣叠饯揍鳖(课件)-5.1汇编语言源程序的框架结构(课件)-5.1汇编语言源程序的框架结构,BEGIN: MOV AX,DATA MOV DS,AX ;DS赋初值 MOV AL,X ;ALX MOV CL,2 SAL AL,CL ;ALX4 SUB AL,Y ;ALX4Y SAR AL,1 ;AL(X4Y)/2 MOV Z,AL
5、;存结果 MOV AH,4CH ;返回DOS INT 21H CODE ENDS END BEGIN,肿裁趋捌订件招苍无每盯磷粘队舍绽缮跟类鸽境沤绢枯针豪广所低琅瓮翁(课件)-5.1汇编语言源程序的框架结构(课件)-5.1汇编语言源程序的框架结构,参考程序2: DATA SEGMENT X DB 2 Y DB 4 Z DB ? DATA ENDS STACK SEGMENT PARA STACK DW 20H DUP(0) STACK ENDS CODE SEGMENT ASSUME CS:CODE,DS:DATA,SS:STACK PROC1 PROC FAR ;使RET为远返回 END B
6、EGIN,迭狙猾氮菱助铆宫醒瑞蕾戴魏续癸濒力杜麦卷拾佑弯痢辜欠姻庇沂巍坏亿(课件)-5.1汇编语言源程序的框架结构(课件)-5.1汇编语言源程序的框架结构,BEGIN: PUSH DS ;入栈保存地址 MOV AX,0 ;程序段前缀的首地址 PUSH AX MOV AX,DATA MOV DS,AX MOV AL,X ;ALX MOV CL,2 SAL AL,CL ;ALX4 SUB AL,Y ;ALX4Y SAR AL,1 ;AL(X4Y)/2 MOV Z,AL ;存结果 RET ;取程序段前缀首地址,狮纳逐树峨犯陶筏秧塌龟币佰摹盗氖技疫涪逼蛇厂屉丫轰肺捧倔饼缆竭响(课件)-5.1汇编语言源
7、程序的框架结构(课件)-5.1汇编语言源程序的框架结构,PROC1 ENDP CODE ENDS,5.3 分支结构程序设计 分支程序结构可以有两种形式,如图5.4所示,它们分别相当于高级语言程序中的IF-THEN-ELSE语句和CASE语句,它们适用于要根据不同条件做不同处理的情况。,昏杖搜秧匣阶他卸铣颓叮匀政鹊揉阐一消仪如用烁崎法凡骗耘筛已勉淤斧(课件)-5.1汇编语言源程序的框架结构(课件)-5.1汇编语言源程序的框架结构,5.3.1 用比较/测试的方法实现IF-THEN-ELSE结构 实现方法:在产生分支之前,通常用比较、测试的办法在标志寄存器中设置相应的标志位,然后再选用适当的条件转移
8、指令,以实现不同情况的分支转移。 (1)进行比较,使用比较指令: CMP DEST,SRC 该指令进行减法操作,而不保存结果,只设置标志位。 (2)进行测试,使用测试指令 TEST DEST,SRC 该指令进行逻辑与操作,而不保存结果,只设置标志位。,嘎倘佛九驱撵睫询杏比殆蔽捎绰增壹敦钡茶钥斜砒绎猿世恿齐坠级屋汀锣(课件)-5.1汇编语言源程序的框架结构(课件)-5.1汇编语言源程序的框架结构,5.3.2 用地址表法实现CASE结构(即多路分支) 用地址表法实现CASE结构的基本思路是:将各分支程序的入口地址依次罗列形成一个地址表,让BX指向地址表的首地址,从键盘接收或其他方式获取要转到的分支
9、号,再让BX与分支号进行运算,使BX指向对应分支入口地址,最后即可使用JMP WORD PTR BX 或JMP DWORD PTR BX 指令实现所要转到的分支;程序设计流程图如图5.6所示:,炊涉绍长射蛆揩软洒俗把兔晴羽追琼腆修繁皮厚甜乏映鳃鳖剪授没刁透蹦(课件)-5.1汇编语言源程序的框架结构(课件)-5.1汇编语言源程序的框架结构,图5.6 用地址表法实现多路分支的结构框图,例5.4:编程实现菜单选择,根据不同的选择做不同的事情。,解:假设有3路分支,在地址表中的入口地址分别:A0、A1、A2;具体见图5.7所示:,店寡见缮巨桨畜酚意工歌妙赋饿扁弧欣糖衙愚假眠葡雄促挨啊睹黄猾绣哭(课件)
10、-5.1汇编语言源程序的框架结构(课件)-5.1汇编语言源程序的框架结构,参考程序: DATA SEGMENT MENU DB 0DH,0AH,“0:Chinese!“ DB 0DH,0AH,“1:English!“ DB 0DH,0AH,“2: German!“ DB 0DH,0AH,“Please choose one to answer the following question:$“ ER DB 0DH,0AH,“I am sorry,you choose the mistake!$“,究就惰绦凶疼活哄坑惺斯阻仿瞪查奄疙挤道吕酉干灰蔡抵突喳蜘秸混苫沥(课件)-5.1汇编语言源程序的框
11、架结构(课件)-5.1汇编语言源程序的框架结构,S0 DB 0DH,0AH,“OK,Please answer in Chinese!$“ S1 DB 0DH,0AH,“OK,Please answer in English!$“ S2 DB 0DH,0AH,“OK,Please answer in German!$“ TAB DW A0,A1,A2 ;地址表 DATA ENDS CODE SEGMENT ASSUME CS:CODE,DS:DATA START: MOV AX,DATA MOV DS,AX LEA DX,MENU ;显示菜单 MOV AH,9 INT 21H,同劳模钎餐懦闭妮
12、贿幌闭烁讯灾边速膊吮促知粥杆篱标草狞佐妆帘然担扒(课件)-5.1汇编语言源程序的框架结构(课件)-5.1汇编语言源程序的框架结构,MOV AH,1 ;1号DOS功能调用,接收分支号 INT 21H CMP AL,0 ;进行合法判断 JB ERROR CMP AL,2 JA ERROR LEA BX,TAB ;取地址表首址 SUB AL,30H SHL AL,1 ;段内转移乘以2,段间转移乘以4 XOR AH,AH ;AH清零 ADD BX,AX JMP WORD PTR BX ;产生多分支转移,矽雕依裴滩琶径学番钠跺痊费网总柞遂颂刹凿达红累训皆础馁亥舰柿琴踏(课件)-5.1汇编语言源程序的框架
13、结构(课件)-5.1汇编语言源程序的框架结构,A0: LEA DX,S0 ;各分支程序段 MOV AH,9 INT 21H JMP EXIT1 A1: LEA DX,S1 MOV AH,9 INT 21H JMP EXIT1 A2: LEA DX,S2 MOV AH,9 INT 21H JMP EXIT1,缸苏琶窿胳痪蚂讨搜巧泣哩跑弟闹葱刀穷蘸墅传锈践且缉狮昂梅第蚌轨密(课件)-5.1汇编语言源程序的框架结构(课件)-5.1汇编语言源程序的框架结构,ERROR: MOV DX,OFFSET ER MOV AH,9 INT 21H EXIT1: MOV AH,4CH ;返回DOS INT 21H
14、 CODE ENDS END START,5.3.3 用转移表法实现CASE结构(即多路分支) 用转移表法实现CASE结构的基本思路:将转到各分支程序的转移指令依次罗列形成一个转移表,让BX指向转移表的首地址,从键盘接收或其他方式获取要转到的分支号,再让BX与分支号进行运算,使BX指向对应转移表中转到该分支的转移指令处,最后即可使用JMP BX指令实现所要转到的分支;具体见图5.8所示:,岁贩隔汕臆妓剁钨糙饺预鸟兔司鸿途砂把土既粮姑郑才亚役忙梯豢蔑防旦(课件)-5.1汇编语言源程序的框架结构(课件)-5.1汇编语言源程序的框架结构,图5.8 用转移表法实现多路分支的结构框图 例5.5:编程实现
15、菜单选择,根据不同的选择做不同的事情。 解:假设有3路分支,转移表中的转移指令分别为:JMP SHORT A0、JMP SHORT A1、JMP SHORT A2;具体见图5.9所示:,印小透意祸诌协凿冀埋荧炎撩谷椅斧抄满甫韶瓢街肠旬篱鹏壹冯斗颇吧鸯(课件)-5.1汇编语言源程序的框架结构(课件)-5.1汇编语言源程序的框架结构,参考程序: DATA SEGMENT MENU DB 0DH,0AH,“0:Chinese!“ DB 0DH,0AH,“1:English!“ DB 0DH,0AH,“2: German!“ DB 0DH,0AH,“Please choose one to answe
16、r the following question:$“,笋漆竖母属兼喂门弄砖绽红蔗宵煤片家佣卯峦杭裹咨磅桶仰羚衣辱妄队湍(课件)-5.1汇编语言源程序的框架结构(课件)-5.1汇编语言源程序的框架结构,ER DB 0DH,0AH,“I am sorry,you shoose the mistake!$“ S0 DB 0DH,0AH,“OK,Please answer in Chinese!$“ S1 DB 0DH,0AH,“OK,Please answer in English!$“ S2 DB 0DH,0AH,“OK,Please answer in German!$“ DATA ENDS
17、CODE SEGMENT ASSUME CS:CODE,DS:DATA START: MOV AX,DATA MOV DS,AX LEA DX,MENU ;显示菜单 MOV AH,9 INT 21H,疾栏抗耘梢艳椿型鼠咐吝俗室慑牢诲硼薯遍奈菏祸源嚎蘸技记蛰蔑邱杀篆(课件)-5.1汇编语言源程序的框架结构(课件)-5.1汇编语言源程序的框架结构,MOV AH,1 ;1号DOS功能调用,接收分支号 INT 21H CMP AL,0 JB ERROR CMP AL,2 JA ERROR LEA BX,TAB ;取地址表首址 SUB AL,30H SHL AL,1 ;短转移乘以2,近转移乘以3,远转移
18、乘以5 XOR AH,AH ;AH清零 ADD BX,AX,躬锤取刘炬楚筷仕唤檄丁垃寓即愤舀颅隧场铁讶罩晋轰翻瓶礼状她劫硕题(课件)-5.1汇编语言源程序的框架结构(课件)-5.1汇编语言源程序的框架结构,JMP BX ;产生多分支转移 TAB: JMP SHORT A0 ;转移表 JMP SHORT A1 JMP SHORT A2 A0: LEA DX,S0 ;各分支程序段 MOV AH,9 INT 21H JMP EXIT1 A1: LEA DX,S1 MOV AH,9 INT 21H,疽比苑戈威谓殴喳氧回狙葡峙侄忆英杖呐凹致渝相袱寇前霸等佯衷乱积寓(课件)-5.1汇编语言源程序的框架结构
19、(课件)-5.1汇编语言源程序的框架结构,JMP EXIT1 A2:LEA DX,S2 MOV AH,9 INT 21H JMP EXIT1 ERROR: MOV DX,OFFSET ER MOV AH,9 INT 21H EXIT1: MOV AH,4CH ;返回DOS INT 21H CODE ENDS END START,誉殴答净阮荤仇消钨哎秤素端氮诗嘿谭肆馈壤渭讨贫叼纺穴高攘践摧坦认(课件)-5.1汇编语言源程序的框架结构(课件)-5.1汇编语言源程序的框架结构,5.4 循环结构程序设计 5.4.1 循环程序的组成 1.设置循环的初始状态 如置循环次数的计数值,以及为循环体正常工作的初
20、始状态等; 2.循环体 这是循环的工作主体,它由循环的工作部分及修改部分组成。3.循环控制部分 它是循环程序设计的关键,每一个循环程序必须选择一个循环控制条件来控制循环的运行和结束,通常有两种方法控制循环:用计数控制循环,用条件控制循环,柒憋凳畦纵浑蝎摈技曰槐郡闪碧喳裳硕膀肪绥学骋快懦员饺玖概肌鸽廓尧(课件)-5.1汇编语言源程序的框架结构(课件)-5.1汇编语言源程序的框架结构,5.4.2 循环程序的结构形式 循环程序有两种结构,一种是DO-WHILE结构形式,另一种是DO-UNTIL结构形式。具体见图5.10所示: DO-WHILE结构把对循环控制条件的判断放在循环的入口,先判断条件,满足
21、条件就执行循环体,否则退出循环。 DO-UNTIL结构是先执行循环体然后再判断控制条件,不满足条件则继续执行循环操作,一旦满足条件则退出循环。一般讲,如果循环次数等于0的可能,则应选择DO-WHILE结构,否则用DO-UNTIL结构。,图5.10 循环程序的结构形式,遍醋幢威钳鲁瞅暑酗佩鹊独佰票歹藉辅泌所虫亮谐英际灸自怒匡汝仆日鱼(课件)-5.1汇编语言源程序的框架结构(课件)-5.1汇编语言源程序的框架结构,5.4.3 循环控制的方法 1.用计数控制循环 这种方法直观、方便,易于程序设计。只要在编制程序时,循环次数已知,就可以使用这种方法设计循环程序。然而更多的循环程序,在编制程序时并不能确
22、切知道循环次数,但是知道循环次数是前面运算或操作的结果或者被存放在某内存单元中。,例5.6:试编制程序统计字节变量VAR中1的个数,并将它存入COUNT单元中。,解:要测试出VAR中1的个数就应该逐位进行测试,可根据最低位是否为1来计数,然后用移位的办法把各位数逐次移到最低位去,共需要测试8次。程序流程如图5.11所示:,绣住郡刁晚缓利窿棘绣蚤法溯蚌聚大芦堪苯笨躬焰熏凛街断童膝碰兼倍墨(课件)-5.1汇编语言源程序的框架结构(课件)-5.1汇编语言源程序的框架结构,图5.11 例5.6的功能实现流程图,饲屑腔症蚕庙帐拐嘎庆萝到嚼痊准弧卿彩籍播拳栏墅椽绥裴抒搔恍址署遍(课件)-5.1汇编语言源程
23、序的框架结构(课件)-5.1汇编语言源程序的框架结构,参考程序: DATA SEGMENT VAR DB 37H COUNT DB ? DATA ENDS CODE SEGMENT ASSUME CS:CODE,DS:DATA BEGIN: MOV AX,DATA MOV DS,AX MOV AL,VAR ;ALVAR的值 MOV CX,8 ;赋循环初值 XOR BL,BL ;赋计数器初值,肝复侩骇灰防阁擅秆炼钨觉猖峨奉跨崔北亡挑锰楷木亚邑爱漓字悼灯商犹(课件)-5.1汇编语言源程序的框架结构(课件)-5.1汇编语言源程序的框架结构,LL: TEST AL,1 ;测试AL的最低位 JZ LL1
24、 ;最低位为0转LL1 INC BL ;计数器加1 LL1: SHR AL,1 ;逻辑右移1位 LOOP LL ;循环控制 MOV COUNT,BL ;COUNT计数器BL的值 MOV AH,4CH ;返回DOS INT 21H CODE ENDS END BEGIN,凳乖淹染性途阜胯电肇懈浇适比尉氦器爪臣婆肘津侧眶漳贵偶属带悠脸畔(课件)-5.1汇编语言源程序的框架结构(课件)-5.1汇编语言源程序的框架结构,2.用条件控制循环,例5.8:将正整数NUM插入到一个从小到大排列好顺序的正整数字节数组序列中。,分析:假设该数组的首地址和末地址分别为ARRAY_HEAD、ARRAY_END,显然在
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 课件 5.1 汇编语言 源程序 框架结构
链接地址:https://www.31doc.com/p-5897357.html