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