汇编调试.docx

上传人:b****9 文档编号:25095204 上传时间:2023-06-05 格式:DOCX 页数:16 大小:214.68KB
下载 相关 举报
汇编调试.docx_第1页
第1页 / 共16页
汇编调试.docx_第2页
第2页 / 共16页
汇编调试.docx_第3页
第3页 / 共16页
汇编调试.docx_第4页
第4页 / 共16页
汇编调试.docx_第5页
第5页 / 共16页
点击查看更多>>
下载资源
资源描述

汇编调试.docx

《汇编调试.docx》由会员分享,可在线阅读,更多相关《汇编调试.docx(16页珍藏版)》请在冰豆网上搜索。

汇编调试.docx

汇编调试

4.1算法:

在数据区中建立一个table表,在表中按十六进制数从小到大顺序放入ASCII码值。

然后将table首地址放入BX中,要查找的十六进制数放入AL中,然后用XLAT命令查表,结果保存在ASCII中。

调试:

—u

—g

—d1428:

0010

结果:

ASCIIDB38H

4.2.算法:

先将两个双字分差成两个字,分别取出,用MUL指令两两相乘,根据乘法定理,用ADD与ADC指令将结果放入相应的存储区。

调试:

—u

—g

—d1428:

0000

结果:

DATA3DB1DF4D840H

014B66DCH

4.3算法:

先将x,y分别取入AL,BL中,利用CMP比较AL,BL在用JE,JA进行条件跳转,分别对AL赋不同的值。

最后放入Z中。

调试:

—u

—g

—d1428:

0000

结果:

Z=01H

4.4.算法:

将A取入AX中用ADD命令将AX与0相加设置符号位SF用JNS判断SF位,即符号正负进行跳转。

如为负则取反。

如为正则不变。

调试:

—u

—d1428:

0000

—g

—d1428:

0000

结果:

ZDW7938H

4.5算法:

将两数的首地址放入SI与DI中,再将两个字存入AX中。

用ADD进行累加后放入相应SUM地址中。

而进位放入DX中,与AX同时累加。

循环一次后SI,DI,BX分别加2共循环4次。

调试:

—u

—d1428:

0000

—g

—d1428:

0010

结果:

SUMDQ855A072E21E60D3A

4.6.算法:

将BYTE_DATA中的二进制数放入AL中,再将AH清零。

用SHL命令取出一位二进制数后再转换为相应ASCII值并存入BUF中,循环8次后显示。

调试:

—u

—d1428:

0000

—g

4.7.算法:

利用DOS的0A号调用输入数据,存入STRING1中,在输出回车,换行。

用SI中的地址取出输出数据放入AL中加密后存入DI指向的存储区。

用DOS的09H号功能输出。

调试:

—u

—g

abcdef

4.8.算法:

将和存入DX中,用CMP指令将DX与10000做比较,若大于则跳出循环,否则累加AX,AX每次加1后再循环。

跳出循环后将AX存入NUM中。

程序错误:

N值需减2.

修改:

在MOVNUM,AX前加SUBAX,02H语句。

调试:

—u

—d1428:

0000

—g

—d1428:

0000

结果:

NUMDW008CH(即N=140)

4.9.算法:

先初始化循环变量DX与CX,将SI指向的数放入AL中,并与下一数进行比较,若高于则交换,并记下标记与BL中,若不高于则SI加1继续循环,跳出循环后DX减1并判断标记BL若循环中无一次交换则跳出循环,否则继续。

调试:

—u

—d1428:

0000

—g

—d1428:

0000

结果:

BUFDB02,03,0D,17,1A,22,2F,59,5A,5D

4.10.算法:

将字符取入AL中,比较AL与0的大小,若相等则取人下一字符,若不等则逻辑左移一位,并判断CF值,若CF=1则NUM自加一,若CF=0则继续左移至跳出循环。

调试:

—u

—g

—d1428:

0007

结果:

NUMDB15(即共21个1)

4.11.算法:

将BUF地址放入SI中,用SI取出第一个ASCII码并与-比较,并保存ZF的值。

若为负数则取下一数,若为正则按十进制与二进制转换法则转换至跳出循环。

后取出ZF判断,若ZF=0则保存AX,否则AX取反后保存。

调试:

—u

—u

—g

345

—d1428:

0000

结果:

BINARYDW0159H

—g=1429:

0000

-32766

—d1428:

0000

结果:

BINARYDW8002H

4.12.算法:

先取串首地址到SI中,设置循环变量CL,调用函数,用传操作指令LODSB取一位ASCII码到AL中并判断。

并转换为相应的二进制数。

结果赋给DX,将DX循环右移4位,即将结果存入高位中,后CH自减1.若为0则跳出循环。

将结果保存在RESULTZ中。

调试问题:

(1)程序无返回DOS命令,无法调试。

所以在RET命令前加MOVAH,4CH和INT21H命令返回DOS

(2)MOVAL,7FH命令多余可去掉。

调试:

—u

—g

—d1428:

0000

结果:

RESULTDWE6A1H

4.13.算法:

调用HEXTOUBCD子过程将十六进制数转为换非组合BCD码,调用UBCDTOASC子过程将非组合BCD码转换成ASCII码。

前一子过程入口参数为AX(待转换的二进制数)与DI(结果单元首地址)分别对十进制数的十百千万做处理,余数保存在DX中。

并DI加1.后一过程取一位BCD码于AL中,转换为ASCII码存入DI指向存储区。

后SI,DI加1.循环。

汇编出错:

missingoperandafterunaryoperator。

程序错误:

重复伪指令REPEAT不能用作标号寻址。

所以将程序中的标号REPEAT改成START.再汇编。

调试:

—u

—d1428:

0000

—g

结果:

显示+22560

4.14.算法:

将LIST1的地址取人SI中,调用函数将表中前两个数相乘,放入第3,,4字节单元中。

后SI加4循环3次,后取出各乘数相加后存入RESULT中。

调试问题:

(1)程序无返回DOS命令,无法调试。

所以在主程序的RET命令前加MOVAH,4CH和INT21H命令返回DOS

调试:

—u

—d1424:

0000

—g

—d1424:

0000

结果:

RESULTDW040CH(即和为1036)

4.15.算法:

主程序先将数组首地址赋给AX后压入堆栈,再将数组个数赋给AX后压入堆栈。

调用子程序,从堆栈恢复数组个数到CX,数组首地址到BX,然后累加到AL中,进位加到AH中,至循环结束。

调试问题:

(1)程序无返回DOS命令,无法调试。

所以在主程序的RET命令前加MOVAH,4CH和INT21H命令返回DOS

调试:

—u

—d1424:

0000

—g

—d1424:

0000

结果:

RESULTDW0239H

4.16.算法:

先将入口参数N赋给AX,后调用子程序。

子程序中先将AX压入堆栈,后减1.判断AX与1是否相等,若不等则进行自我调用。

若相等则取堆栈数到BX中,与AX相乘。

—u

—d1424:

0000

—g

—d1424:

0000

结果:

FNDW13B0H(即为7的阶乘为5040)

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 法律文书 > 起诉状

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1