1625-5 王子昂 总结《2017年4月17日》 【连续第198天总结】
A. 汇编语言 综合设计1 80%
B. 综合设计中的三个子程序进行了上机实验,不溢出除法进行的很顺利,除了刚开始写的时候由于公式里没说余数哪去了所以也没写
检查了一下公式,重新理解了余数的出现地点然后将其正确输出即可
代码:
assume cs:code
code segment
start: mov ax,4240H
mov dx,0FH
mov cx,0AH
call divdw
mov ax,4c00h
int 21h
divdw: mov bx,ax
mov ax,dx
mov dx,0
div cx
mov bp,ax
mov ax,bx
div cx
mov cx,dx
mov dx,bp
ret
code ends
end start
第三个子程序是数值显示,将int型数据(word)转换为char型(字符串)。
主要思路是将数据逐次除以10,商与对应字符的ASCII值有差30H的对应关系,因此可以依次得到余数然后转换为字符型存入
然而这种方法得到的字符串一定是逆序的,书上没有进行相关说明
我有两种想法:
一、预估长度,然后直接跳到指定字符串的末尾进行逆向输出;但是由于长度是无法提前知道的,并且程序中判断长度的方法是商是否为0;因此只能以最大长度做考虑,当给定数值小于最大长度(word型数据最大65535即5位)时,将会在前方补0,比较不合题意
二、开辟另一个区域进行中转,先逆向放入,再逆向一次放入指定字符串的内存区域。考虑一下使用栈会比较方便,直接进行push和pop即可。
于是考虑实现了第二种,代码如下:
assume cs:code,ds:data,ss:stack
data segment
dw 8 dup(0)
data ends
stack segment
db 32 dup (0)
stack ends
code segment
start:
mov ax,data
mov ds,ax
mov si,0
mov ax,stack
mov ss,ax
mov sp,10H
mov ax,22666 ;ax not equal one
mov dx,0
call dtoc
mov ax,4c00h
int 21h
dtoc: ;mov bp,2
mov bx,0
push bx
dtocl: mov bx,10
div bx
add dx,30H
push dx
mov cx,ax
jcxz go
mov dx,0
; inc bp
loop dtocl
go: pop [si]
mov cx,[si]
jcxz ok
add si,2
loop go
ok: ret
code ends
end start
:但是不知道为什么,当循环进行到最后一位'1'时,mov cx,ax一定会报错:
"The NTVDM CPU has encountered an illegal instruction.
CS:0000 IP:0077 OP:f0 37 05 0e 02 chose'Close' to terminate the application"
查了一下,有说是栈太小了导致溢出,也有说是虚拟机的设置和DOS的连接问题。但是改了栈的大小也没有用╮(╯_╰)╭尝试更改了代码,仍然会报这个错,一直位于对cx的赋值命令中
修改ax的初值,即修改数据的第一位为非'1'时则不会报错。不知道怎么回事,明天看看综合设计
C. 明日计划
汇编语言 综合设计1