一字节BCD码转ASCII码的算法及源码

   一字节压缩BCD码是两位0~9的数字,4位二进制数对应一位BCD码。所以关键是要将两个4位二进制数分离开来。“分离”可以用移位指令和逻辑运算指令来实现,然后用加30H的加法,便可以得到相应的ASCII码。
    1. 这里有个问题,30H从哪里来?很简单,ASCII都是固定的,起始数字0对应的ASCII是30H,数字1对应的ASCII码数21H,数字2对应的ASCII码数22H......所以单个数字的ASCII码对应在30H和39H之间,而1位BCD(四位二进制数)码对应的高位和低位,存放的刚好已经是0H~9H的值,刚好是对应数字1-9,所以直接加上30H就好了。
    2.需要注意高低位的移位操作就可以了。
    3.汇编代码如下:
     DATA SEGMENT
     BCCD-BUF DB 96H
     ASC-BUF DB 2DUP (?)
     DATA ENDS
     CODE  SEGMENT
         ASSUME CS:CODE,DS:DATA
     START:MOV AX,DATA
           MOV DS,AX
           MOV AL,BCD-BUF
           MOV BL,AL
           MOV CL,4
           SHR AL,CL
           ADD AL,30H
           MOV ASC-BUF,AL
           AND BL,0FH
           ADD BL,30H
           MOV ASC-BUF+1,BL
    CODE ENDS
         END START
    

   
 
 

猜你喜欢

转载自nannan408.iteye.com/blog/967524
今日推荐