经典汇编语言教程:10.3 数据转换程序举例

10.3 数据转换程序举例

例10.7是用“用16位除10”的方法从低向高依次得到每位的数值,但若待输出的数据是32位,用10除之后,其商很可能会超过16位,所以,不能简单地引用例10.7的方法来输出32位二进制。

假设:32位二进制数Z为A×216+B,其中:A和B都是16位二进制数。 用10去除A,得:A=A1×10+A2,于是, 

  (1) 

假设A2×216+B被10除后所得的商和余数分别为B1和C1(B1≥0,C1≥0)。 

利用式(1)和“A2<10”,我们不难看出:Z的个位就是C1和B1<216。 

令Z1=A1×216+B1,显然,Z1就是Z/10所得到的商。 

对于Z1,再利用式(1)得到商Z2和C2。……,重复上面的步骤,直到所得商为0为止。

下面的例10.9就是利用上面方法来输出32位二进制数值。

例10.9编写一个子程序,该子程序能把32位二进制变量的数值以十进制形式输出出来。若该数值为负数,则需要输出负号"-",否则,不输出符号。

解:
.MODEL SMALL, C
.DATA
CR = 13
LF = 10

Data1

DD    908976789
.CODE
;子程序Display是按十进制输出32位二进制数值SOURCE
DisplayPROC USES AX BX CX DX SI DI SOURCE:DWORD
LOCALFLAG:BYTE;定义一个字节类型的局部变量FLAG
MOVBX, WORD PTR [SOURCE]
MOVCX, WORD PTR [SOURCE+2]
MOVFLAG, 0;FLAG=0——正数
CMPCX, 0
JGEnext
INCFLAG;FLAG=1——负数
NOTBX
NOTCX
ADDBX, 1;能否用指令INC BX?
ADCCX, 0;上四条指令把32位数CX-BX变为正数
next:
XORDI, DI;压入堆栈字符的个数
MOVSI,10;用10来除
.REPEAT;本循环把32位二进制数转换成十进制

XOR

DX, DX;数的字符串存入堆栈之中

MOV

AX, CX

DIV

SI

MOV

CX, AX

MOV

AX, BX

DIV

SI

ADD

DL, '0'

PUSH

DX

INC

DI

MOV

BX, AX
.UNTILBX==0 && CX==0
.IF FLAG==1;判断前面转换的数是否为负数

MOV

AL, '-';若是,把符号'-'压入堆栈

PUSH

AX

INC

DI
.ENDIF
MOVCX, DI
.REPEAT;本循环把堆栈中的字符串显示出来

POP

DX

MOV

AH, 2

INT

21H
.UNTILCXZ
MOVDL, CR;下面六条指令显示回车、换行
MOVAH, 2
INT21H
MOVDL, LF
MOVAH, 2
INT21H
RET
DisplayENDP
.STARTUP
INVOKEDisplay, Data1
INVOKEDisplay, -123456789
.EXIT0
END

上页:上一课 下页:下一课

经典汇编语言教程·相关目录

第1章 汇编语言的由来,数据类型第2章 CPU资源和存储器
第3章 操作数的寻址方式第4章 标识符和表达式
第5章 微机CPU的指令系统第6章 程序的基本结构
第7章 子程序和库第8章 输入输出和中断
第9章 宏第10章 应用程序设计
第11章 数值运算协处理器第12章 汇编语言和C语言
汇编语言重要附录Windows API函数大全
版权所有 © 中山市飞娥软件工作室 证书:粤ICP备09170368号