【微机汇编语言学习笔记(六)】 ASCII码表示的十进制转换为二进制

本文介绍了一种使用汇编语言将ASCII码表示的十进制数转换为二进制数的方法。通过循环计算,实现了从ASCII码到十进制数再到二进制数的转换过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

十进制数转换为二进制数的方法:从十进制数的最高位Dn开始作乘10加次位的操作,将结果乘以10再加下一个次位数,如此重复便可求出二进制数的结果。

汇编语言实现ASCII码表示的十进制转换为二进制

;功能描述:将ASCII码表示的十进制转化为二进制

sstack segment stack
       dw  64 dup(?)
sstack ends

data segment 
sadd db 30h,30h,32h,35h,36h     ;十进制:00256
data ends

code segment 
     assume   cs:code,ds:data

start: mov ax,data          ;
       mov ds,ax
       mov ax,offset sadd   ;把sadd的首地址送给ax
       mov si,ax
       mov bx,000ah     ;用于乘10操作
       mov cx,0004h     ;初始化循环次数
       mov ah,00h       ;将ax高八位清零
       mov al,[si]      ;将第一个数据放入al中
       sub al,30h       ;减30H,变为原十进制数大小
a1:    imul bx          ;将原十进制数乘10
       mov dx,[si+01]   ;取下一个数
       and dx,00ffh     ;dx高八位清零
       adc ax,dx        
       sbb ax,30h
       inc si
       loop a1

a2:jmp a2
code ends
     end start

转换结果在ax寄存器中显示为0100。

 

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

单片机学习之路

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值