王爽《汇编语言》实验10:编写子程序dtoc 解答

assume cs:code

data segment
	;保存转换后的ASCII
	db 10 dup(0)
data ends

code segment
start:
	mov ax,12666
	mov bx,data
	mov ds,bx
	mov si,0
	call dtoc

	mov dh,8
	mov dl,3
	mov cl,2
	call show_str

	mov ax,4c00h
	int 21h

dtoc:
	push ax
	push di
	push cx
	push dx
	push si
	mov di,0 ;记录入栈多少次,就是有多少位数
s1:
	mov cx,10d ;除10
	mov dx,0
	div cx

	mov cx,ax ;如果商为0,那么求值完成
	jcxz s2

	add dx,30h
	push dx ;把求得的ACSII入栈
	inc di
	jmp short s1
s2:
	add dx,30h ;最后一次也要记录
	push dx
	inc di

	mov cx,di
s3:
	pop ax
	mov [si],al ;ACSII码只占用了低8位
	inc si
	loop s3

	pop si
	pop dx
	pop cx
	pop di
	pop ax
	ret

show_str:
	push cx	;保存用到的寄存器
	push si
	push es
	push di
	push bx

	mov ax,0b800h
	mov es,ax

	mov al,0a0h	;一行的总列数160字节
	dec dh		;行号减1,因为是从0开始的
	mul dh		;计算行开始偏移地址
	mov bx,ax

	mov al,2
	mul dl		;计算列
	sub ax,2	;列也是从0开始,而且一个字符占两个字节
	add bx,ax	;求出开始位置	
	
	mov di,0
	mov al,cl
	mov ch,0	;高8位为0
s:	
	mov cl,ds:[si]	;判断是否到了字符结束
	jcxz ok
	mov es:[bx+di],cl
	mov es:[bx+di+1],al

	inc si
	add di,2
	jmp short s
ok:
	pop bx
	pop di
	pop es
	pop si
	pop cx
	ret

code ends

end start

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值