ImageVerifierCode 换一换
格式:DOC , 页数:10 ,大小:62.04KB ,
资源ID:2562738      下载积分:3 金币
验证码下载
登录下载
邮箱/手机:
验证码: 获取验证码
温馨提示:
支付成功后,系统会自动生成账号(用户名为邮箱或者手机号,密码是验证码),方便下次登录下载和查询订单;
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

开通VIP
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.zixin.com.cn/docdown/2562738.html】到电脑端继续下载(重复下载【60天内】不扣币)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  
声明  |  会员权益     获赠5币     写作写作

1、填表:    下载求助     索取发票    退款申请
2、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
3、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
4、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
5、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【w****g】。
6、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
7、本文档遇到问题,请及时私信或留言给本站上传会员【w****g】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。

注意事项

本文(第五章程序设计方法和上机调试.doc)为本站上传会员【w****g】主动上传,咨信网仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知咨信网(发送邮件至1219186828@qq.com、拔打电话4008-655-100或【 微信客服】、【 QQ客服】),核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载【60天内】不扣币。 服务填表

第五章程序设计方法和上机调试.doc

1、个人收集整理 勿做商业用途第五章 程序设计方法和上机调试5.1 汇编语言程序设计方法汇编语言设计基本要求:结构化、简明、易读、易调试、易维护(修改、扩充等)执行速度快:占用的存储空间少 相矛盾,根据实际权衡汇编语言程序设计的基本步骤:分析问题,建数学模型,确定算法绘制流程图或写出步骤安排分配空间及寄存器,根据框图写程序静态检查上机调试程序结构类型:l 顺序结构l 分支结构 不同的情况有不同的做法l 循环结构 重复做的工作l 子程序 多次重复使用的、具有通用性便于共享的部分。子程序前面应加必要的说明;子程序名称;功能;入口参数;出口参数;所用寄存器例1:查平方表程序- 顺序结构 015的平方值存

2、在TABLE开始的16个单元.任给一自然数M在XX单元中。查表求M的平方值,并将结果存入YY单元中.STACK SEGMENT PARA STACK STACK DB 50 DUP(?)STACK ENDS; 组合类型,本段可以被别的段引用 类别DATA SEGMENT PARA PUBLIC DATA TABLE DB 0,1,4,9,16,25,36,49,64,81 DB 100,121,144,169,196,125 XX DB 6 YY DB ? DATA ENDS ; CODE SEGMENT ASSUME CS:CODE,DS:DATA,SS:STACK 段寄存器指向说明CS指向

3、CODE段 START PROC FAR PUSH DS MOV AX,0 将DOS段值和偏移量(零)入栈。 PUSH AX MOV AX,DATA MOV DS,AX;当前数据段 MOV BX,OFFSET TABLE ;取表的偏移量 MOV AH,0 可用MOV AL,XX MOV AL,XX XLAT 代替 ADD BX,AX ;取要查数的偏移量 MOV AL,BX ;查表MOV AL,XX BX MOV YY,AL RET START ENDP CODE ENDS END STARTP67页:XLAT 换码指令 完成一字节的查表转换 AL(BX+AL) 表的首址放入BX,相对首址偏移值

4、入AL。TABLEXXXXYY01424E1624例2: 数据块传送- 分支结构 将内存中首址为STG1、长度为STRSE的数据块传送到首址为STG2的区域中去。无重迭 STG1+STRSE1STG2 或STG2+STRSE1STG1有重迭时 STG1+STRSE1STG2 STG2+STRSE1STG1分析可知 第一种情况用减量传送STG1+STRSE1STG2,其它都用增量传送。DATA SEGMENTSTRG DB 100 DUP(?)STG1 EQU STRG+7STG2 EQU STRG+25STRSE EQU 50 ;传送50字节数据DATA ENDS;STACK SEGMENT

5、PARA STACK STACK DB 100 DUP(?) ;定义100个字节堆栈STACK ENDS;CODE SEGMENT ASSUME CS:CODE,DS:DATA,ES:DATA,SS:STACKGOO PROC FAR 主模块用START PUSH DS MOV AX,0 DOS入栈 PUSH AX MOV AX,DATA 指向当前数据段 MOV DS,AX MOV ES,AX MOV CX,STRSE ;计数器值 MOV SI,OFFSET STG1;数据源指针 MOV DI,OFFSET STG2;目的数据指针 CLD ;增量传送 MOV BX,SI PUSH SI ;保护

6、源操作数指针 ADD BX,STRSE1 ADD SI,STRSE1 ;源最后一个数指针 CMP BX,DI CMP SI,DI ;比较STG1+STRSE1STG2.减 POP SI ;恢复SI STG2。增(?) JB OK ; 低于则转移 STD ;减量传送 ADD SI,STRSE1 ;源尾部 ADD DI,STRSE1 ;目的尾部 OK:REP MOVSB ;重复传送 RET GOO ENDP CODE ENDSEND GOO例52 吴 分支结构存储器中由一串字符串首址为BUF,字符串长度N小于256,要求分别计算出其中数字、字母和其它字符的个数,存放在字符串的下面三个单元中。解:本

7、题根据字符的ASCII码值范围进行判断,字母41H5AH,数字30H39HDATA SEGMENTBUF DB NDB 01H,38H,47H,60H,76HNUM DB 3 DUP(?)DATA ENDS;STACK SEGMENT PARA STACK STACK DB 100 DUP(?) ;定义100个字节堆栈STACK ENDS;CODE SEGMENTMAIN PROC FAR ASSUME CS:CODE,DS:DATA, SS:STACKSTART :PUSH DS MOV AX,0 DOS入栈 PUSH AX MOV AX,DATA 指向当前数据段 MOV DS,AX MOV

8、 CH,N ;数组个数N CH MOV BX,1MOV DX,0 ;DH计数字个数,DL计字母个数LP: MOV AH,BUF BX ;第一次取01H AH CMP AH,30HJL NEXT ;小于0 转CMP AH,39HJG ABC ;大于9转INC DH ;数字个数+1JMP NEXTABC: CMP AH,41H JL NEXT ;小于A 转CMP AH,5AHJG NEXT ;大于Z转INC DL ;字母个数+1NEXT: INC BX ;数组地址+1 DEC CH ;计数1 JNZ LP ;不为0跳转继续MOV BUF BX,DH ;数字个数送内存单元MOV BUF BX+1,D

9、H ;字母个数送内存单元MOV AH,NSUB AH,DH ;计算其它字符个数SUB AH,DLMOV BUF BX+2,AH ;其它字符个数送内存单元RETMAIN ENDPCODE ENDS END STARTP124 例6 在一个带符号的字类型的数据串中,找出最大值-循环结构STT SEGMENT PARA STACK STACK DB 50 DUP(?)STT ENDS;DATA SEGMENTVALUES DW 2,21,87,23,14,90;0002H,0015H,0057H,FFE9H,000EH,005AHCOUNT EQU -VALUES ;数据串长度字节数,-(地址计数器

10、值)YY DW ?DATA ENDS;CODE SEGMENT ASSUME CS:CODE,DS:DATA,SS:STTSTART PROC FAR PUSH DS MOV AX,0 ;DOS交权时,DOS的段值和偏移量入栈. PUSH AX MOV AX,DATA 指向DS段(当前) MOV DS,AX MOV BX,OFFSET VALUES ;数据首址偏移量 MOV CX,COUNT/21 ;量计数器,比较n1次 MOV AX,BX ;取第一个放AX中,做初始最大值。FINDM:ADD BX,2 ; 下移一个数据 CMP AX,BX ;原来的最大值与现在的比 JG TESTIP ;若原

11、来的大、不变、转移 MOV AX,BX ;否则,换新的最大值入AXTESTIP: LOOP FINDM ;检查 循环是否结束 MOV YY,AX ; 将最大值放入单元 RETSTART ENDPCODE ENDS END START方法:将第一个数据作为初始最大值,再将后面的数据与其比较,将最大值放入AX中。P131页 例10.在数据段定义了两个数组,编一个程序实现对两数组分别求和。要求采用子程序调用形式。 调用程序用CALL指令调用之前把子程序所需参数入栈,以便子程序运行时使用这些参数.当子程序返回后,这些参数已不再有用,因此子程序结束时的RET指令应使用带常数的返回指令。以便堆栈恢复原态.

12、STACK SEGMENT PARA STACK STACKSPAE DW 20 DUP(?)TOP EQU LENGTH SPAESTACK ENDS;DATA SEGMENT ARY1 DB 1,2,3,4,5,6,7,8,9,10NUM1 EQU -ARY1 ;求数组1长度SUM1 DW ?ARY2 DB 20,30,40,10,21,33NUM2 EQU $-ARY2 ;求数组2长度SUM2 DW ?DATA ENDS;MAIN SEGMENT ASSUME CS:MAIN,DS:DATA,SS:STACKSTR:PUSH DS MOV AX,0 DOS入栈 PUSH AX MOV A

13、X,DATA 指向当前数据段 MOV DS,AX MOV AX,NUM1 PUSH AX ;数组长度进栈。参数1 MOV AX,OFFSET ARY1 PUSH AX ;数组首址偏移量进栈,参数2 CALL FAR PTR SUM ;CS、IP先后进栈 MOV AX,NUM2 PUSH AX MOV AX,OFFSET ARY2 PUSH AX CALL FAR PTR SUM HLTMAIN ENDS ;主程序结束;功能:数组求和;入口参数:数组长度、首址偏移量。出口:;所用寄存器AX、BX、CX、BPPROCE SEGMENT ASSUME CS:PROCE ,DS:DATA,SS:STA

14、CKSUM PROC FAR PUSH AX PUSH BX PUSH CX PUSH BP MOV BP,SP PUSHF MOV CX,BP+14 ;参数1,因在PUSHF之前SP移入BP,所以+14是参1。 MOV BX,BP+12 ;参数2,首址偏移量 MOV AX,0 ADN: ADD AL,BX INC BX ADC AH,0 ;进位加进去 LOOP ADN MOV BX,AX ;数据之和送结果单元 POPF ;标志出栈 Flag(sp+1,sp),spsp+2 POP BP POP CX POP BX POP AX RET 4 ;舍弃两个参数返回原来参数入栈两次。SUM ENDP

15、PROCE ENDSEND STR5。2 汇编语言上机调试过程进入用户目录进行程序编辑. loginF:cd userF:user5F:user5Edit保存: Alt进入主菜单.Save。 save as xyz.ASM.MASM Source filename。ASM:文件名 源文件 Object filenamexyz.OBJ: 目标文件 Source Listing NUL。LST: 打印文件 Cross ReferenceNOL.CRF: 交叉索引文件 0 Warning Errors0 Severe ErrorsDOS状态下 TYPE XYZ.ASM LST 均可打印出来连接 Li

16、nk汇编程序建立的目标码文件即.obj文件必须经过连接以后,才能成为可执行文件.即。EXE文件。 Object Modules.OBJ:xyz 目标文件 RON Filexyz.EXE: 可执行文件 List FileNUL。MAP: 内存分配图文件 Libraries 。LIB: 库文件若有多个要连接的OBJ文件,应一次打入,各OBJ文件名词用“+”号相间隔。运行文件 XYZ调用DEBUG程序调试在DOSDEBUGPathfilemame. user5xyz.exe即出现“一提示符,说明系统已在DEBUG管理之下。一、 显示内存单元命令。 D 或D地址 从地址在显示80H个字节。 当前地址开

17、始 或D范围 显示80H字节二、修改存储单元内容命令EE 地址 显示原来单元内容 输入一个字节的16进制数,按空格键,则修改完成。接着显示下一单元的地址和原有内容。按回车结束此命令。三、检查和修改寄存器内容的命令RR 显示所有寄存器内容R AX 显示AX寄存器内容-RF 显示和修改标志位状态置位:OY DN EI NG ZR AC PE CY-复位:NV UP DI PL NZ NA PO NC除跟踪标志T之外。四、 运行命令 G-G =执行的起始地址偏移量断点地址1断点地址2最多可设置10个断点。五、跟踪命令T(单步)T=指定地址 执行指定地址处的一条指令停下来,显示CPU所有寄存器和标志状

18、态。T 从CS:IP执行一条指令=指定地址值 执行的指令条数。六、 反汇编命令U -U 显示32个字节的源程序内容 U 范围P118页例: DATA SEGMENT TABLE DB 0,1,4,9 XX DB 2 YYO DB RESULT: DATA ENDS ;CODE SEGMENT ASSUME CS:CODE,DS:DATA,SS:STACK 段寄存器指向说明CS指向CODE段 START PROC FAR PUSH DS MOV AX,0 将DOS段值和偏移量(零)入栈。 PUSH AX MOV AX,DATA MOV DS,AX;当前数据段 MOV BX,OFFSET TABL

19、E ;取表的偏移量MOV AH,0 ;可用MOV AL,XX MOV AL,XX ; XLAT 代替 ADD BX,AX ;取要查数的偏移量 MOV AL,BX ;查表MOV AL,XX BX MOV YY,AL RET START ENDP CODE ENDS END START MOV AL,BX ADD AL,30H ;转换成ASCII码值 MOV YY,AL 加 MOV AH,9 MOV DX,OFFSET YYO INT 21H RET5。3 宏汇编与条件汇编 源程序中若有的程序段要多次使用,可不重复书写,而用一条宏指令来代替。格式:宏指令名 MACRO (形式参量表) 宏定义体 E

20、NDM宏调用格式:宏指令名 实元表.例:8位带符号数相乘,结果放入RESULT单元 被乘数 乘数 结果 宏定义 MULTPLY MACRO OPRD1 ,OPRD2, RESULT PUSH AX MOV AL,OPRD1 IMUL OPRD2 ;AXALOPRD2 MOV RESULT,AX POP AX ENDM宏调用:MULTPLY 240,BL,SAVC 宏展开:即在汇编时产生+ PUSH AX +MOV AL,240+IMUL BL+MOV SAVC,AX+POP AX 实元可以是常数、寄存器、存储单元名及地址或表达式也可以是操作码。例 移位指令都以S打头,后面可以用宏。除了MACR

21、O之外,还有宏汇编伪指令REPT、IRP、IRPC也都以ENDM作为结束符.二. PURGE(用来取消宏定义)与LOCAL格式:PURGE 宏指令名,LOCAL 用来说明宏体内的标号为局部标号,以免多次调用宏定义时标号重复而出错。格式: LOCAL 局部标号表三。 宏指令与子程序的区别宏指令是为了简化源程序的书写,汇编时,把宏定义体插入到宏调用处。所以宏指令并没有简化目标程序,不节省目标程序所占的内存单元。子程序方法简化了目标代码,节省空间,但每次调用都要保护现场而后恢复,这样执行时间长点,速度稍慢。选用时根据实际情况,速度是主要矛盾时,用宏指令;存储空间是主要矛盾时选用子程序方法。四。 条件汇编 根据条件决定一段源程序是否在该程序中起作用,起作用的则将其生成目标程序代码,否则,不生成。多种格式:IFXX 条件表达式 (语句体1) ELSE (语句体2)ENDIF有:IF、IFE、IFDEF、IFNDEF、IFB、IFNB、计算条件:为真时汇编。

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        获赠5币

©2010-2024 宁波自信网络信息技术有限公司  版权所有

客服电话:4008-655-100  投诉/维权电话:4009-655-100

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :gzh.png    weibo.png    LOFTER.png 

客服