加法汇编程序
⑴ 简单的汇编加法程序
; 本程序通过编译,运行正确
Code Segment
Assume CS:Code,DS:Code
W dw 378
X dw 456
Z dw 269
Start: push cs
pop ds ;使数据段与代码段同段
mov ax,X
sub Z,ax ;Z-X→Z
mov ax,W
add Z,ax
Exit_Proc: mov ah,4ch ;结束程序
int 21h
Code ENDS
END Start ;编译到此结束
⑵ 汇编语言中加法程序(初学汇编,希望有程序说明)
data segment
a db 1
b db 2
c db 3
d db ?
data ends
code segment
assume cs:code,ds:data
start:
mov ax,data
mov ds,ax
cmp a,0
jnz next1
cmp b,0
jnz next1
cmp c,0
jnz next1
mov al,a
add al,b
add al,c
mov d,al
jmp tj
next1:
mov a,0
mov b,0
mov c,0
tj:
mov ah,4ch
int 21h
code ends
end start
请参考
⑶ 用汇编实现一个加法的exe程序
过程如下:
1、编辑:用编辑软件(EDIT.EXE或记事本)形成源程序(.ASM),如:LX.ASM;
2、汇编:用汇编程序(MASM.EXE)对源程序进行汇编,形成目标文件(.OBJ),格式如下:MASM
LX.ASM;
3、连接:用连接程序(LINK.EXE)对目标程序进行连接,形成可执行文件(.EXE),格式如下:LINK
LX.OBJ;
4、执行:如果结果在屏幕在显示,则直接执行可执行文件。
5、调试:用调试程序(DEBUG.EXE)对可执行文件进行调试,格式如下:DEBUG
LX.EXE
⑷ 汇编加法程序
;经验证,下式结果正确
;S=86H*34H-22H=1B38H-22H=1B16H
code segment
assume cs:code,ds:code
org 100h ;COM格式
start:
push cs
pop ds
mov ax,0e53h ;显示'S'
int 10h
mov al,'=';显示'='
int 10h
call @IN
mov dl,al
mov bl,2ah;"*"
call show ;显示'H*'
call @IN
mov dh,al
mov bl,2dh ;"-"
call show ;显示'H-'
call @IN
mov ah,0
mov bp,ax
mov bl,3dh ;"="
call show ;显示'H='
mov ah,0
mov al,dl ;AL←86H
mov bl,dh ;BL←34H
mul bl ;86H*34H
;未考虑不够减的情况
sub ax,bp ;AX←AX-22H
mov cx,4
mov dx,ax
next:
push cx
mov cl,4
rol dx,cl
mov ax,dx
and al,0fh ;取出一位
or al,30h ;二进制转换为Ascii
cmp al,'9';比9小直接显示
jb T2
add al,7 ;是A`F的,加7校正
T2:
mov ah,0eh ;显示Ascii
int 10h
pop cx
loop next ;下一位
mov ax,0e48h ;'H'
int 10h
mov ah,0
int 16h ;暂停
mov ah,4ch
int 21h ;结束
@IN:;可输入两位十六进制数
xor bx,bx ;BX←0
mov cx,4
@1:call input
mov bl,al
shl bl,cl ;BL←BL*10H
call input
add al,bl ;AL←两位十六进制数
ret
input: ;仅允许输入并显示0-9和A-F
mov ah,0
int 16h ;无回显键盘输入
cmp al,'0';十六进制数 0-F
jb input ;为有效输入
cmp al,'9'
jbe Q1
and al,0dfh ;大小写,同转为大写
cmp al,'A';"A(a)"
jb input
cmp al,'F';"F(f)"
ja input
Q1:mov ah,0eh
int 10h ;显示有效输入
sub al,30h ;0-9之间,Ascii转换为二进制
cmp al,9
jbe Q3
sub al,7
Q3:ret
show:
mov ax,0e48h ;"H"
int 10h
mov al,bl
int 10h
ret
code ends
end start
⑸ 汇编语言中的加减法
(加减指令,既作为无符号数影响标志位CF,AF,又作为有符号数影响标志OF,SF。想了半天终于搞清楚了,CF标志反映最高位的进借位情况,而OF反映结果是否溢出,这里的结果是目的操作数中的结果,进借位它是不管的。你这样想的原因是,考虑到CF为1,则肯定溢出了,但是目的操作数中只能保存溢出后的值,丢掉了最高位,所以就不一定溢出了。看例子:
MOV
AX,7896H;
ADD
AL,AH;
;执行完后CF=1,AL=0EH,但是OEH不溢出,所以OF=0;
后面一句也不对吧。)
以上是我个人的理解。
以下是复制别人的理解:
CF
比较简单吧,
没有什么特别的.
OF
表示的带符号数进行运算是否溢出.
96+78,
一个是正数,
一个为负数,
相加肯定是不会有溢出的.
OF
溢出只可能发生在两个相同符号的数值相加,
或者是不同符号数相减.
如果是从算法判断上来看,
如果是在运算时,
次高位向最高位和最高位向
CF
位产生进位情形一致的话,
OF=0;
否则
OF=1.
96
10010110
+78
01111000
10E
100001110
这里,
次高位和最高位都产生了进位,
情形一致,
所以
OF=0
16
00010110
+78
01111000
08E
10001110
这里,
次高位向最高位产生了进位,
而最高位没有向
CF
产生进位,
所以
OF=1
而且,
结果也是,
两个正数相加,
结果为负数了,
显然溢出
还有两种情况,
也是类似的.
一个是都没有产生进位,
那应该是两个小的正数相加,
结果还是正数,
没有溢出;
另外就是次高位没有产生进位,
但最高位产生进位了,
这应该是两个负数相加,
由于次高为位没有产生进位,
所以,
最高位,
也就是符号位结果为
0,
是正数,
显然也是溢出了.
⑹ 用汇编语言编一个加法程序
;输入格式必须为A+或-或/或*B=
;按回车结束运算数为(0~255)
DATAS SEGMENT
x db 20 p(?)
y db 'chu cuo le','$'
DATAS ENDS
CODES SEGMENT
ASSUME CS:CODES,DS:DATAS
START:
MOV AX,DATAS
MOV DS,AX
JMP A
KAISHI:
;回车换行
MOV DL,0DH
MOV AH,02H
INT 21H
MOV DL,0AH
INT 21H
LEA SI,X
SUB AX,AX
SUB BX,BX
SUB CX,CX
SUB DX,DX
;输入数字
A: MOV AH,01H
INT 21H
CMP AL,0DH
JZ L
CMP AL,30H
JB B
CMP AL,3AH
JNB F
SUB AL,30H
MOV CH,AL
MOV AL,BL
MOV BL,0AH
MUL BL
ADD AL,CH
MOV BL,AL
JMP A
;判断+-*/=
B: CMP AL,2BH
JNZ K
MOV X[SI],BL
INC SI
MOV CL,0H
AND BL,0
JMP A
K: CMP AL,2DH
JNZ D
MOV X[SI],BL
INC SI
MOV CL,01H
AND BL,0
JMP A
D: CMP AL,2AH
JNZ E
MOV X[SI],BL
INC SI
MOV CL,02H
AND BL,0
JMP A
E: CMP AL,2FH
JNZ T
MOV X[SI],BL
INC SI
MOV CL,03H
AND BL,0
JMP A
;计算
F: MOV [SI],BL
CMP AL,3DH
JNZ T
LEA SI,X
MOV AL,X[SI]
INC SI
MOV BL,X[SI]
CMP CL,0
JNZ G
ADD AL,BL
JMP J
G: CMP CL,01H
JNZ H
SUB AL,BL
JMP J
H: CMP CL,02H
JNZ I
AND AH,0
MUL BL
JMP J
I: AND AH,0
CMP CL,03H
DIV BL
;输出
J: AND AH,0
CMP AL,100
JB ER
MOV BL,100
DIV BL
MOV CL,AH
ADD AL,30H
MOV DL,AL
MOV AH,02H
INT 21H
MOV AL,CL
ER: CMP AL,10
JB YI
MOV BL,10
AND AH,0
DIV BL
ADD AL,30H
MOV DL,AL
MOV CL,AH
MOV AH,02H
INT 21H
MOV AL,CL
YI: ADD AL,30H
MOV DL,AL
MOV AH,02H
INT 21H
JMP KAISHI
T: LEA DX,Y
MOV AH,09H
INT 21H
JMP KAISHI
L: MOV AH,4CH
INT 21H
CODES ENDS
END START
⑺ 汇编加法的实现
ASSUMECS:CC,DS:CC
;----------------------------
CCSEGMENT
XDB5
YDB4
ZDB?
TIPDB'z=',36
BEG:
MOVAX,CC
MOVDS,AX
MOVDL,X
ADDDL,Y
MOVZ,DL
LEADX,TIP
MOVAH,9
INT21H
MOVDL,Z
ADDDL,'0'
MOVAH,2
INT21H
EXIT:
MOVAH,4CH
INT21H
;----------------------------
CCENDS
ENDBEG
⑻ 如何用汇编语言编一个计算加法的程序
输入格式必须是A +或 - 或/或* B =
;按Enter年底计算数(0255)
DATAS段
所述DB 20 p的(?)
DB'CHU痤勒','$'
DATAS ENDS
CODES分部
ASSUME <CS:CODES过,DS的人:DATAS START如下:
MOV AX,DATAS
MOV DS,AX
。JMPA
KAISHI:
;回车换行符
MOV DL,0DH MOV的AH,02H INT 21H
MOV DL,0AH
INT 21H
的LEA SI中,X
SUB AX的,AX
SUB的BX,BX
SUB CX,CX
SUB DX,DX
;输入数字
- 答:MOV AH,01H
INT 21H
CMP AL,0DH
> JZ
的CMP AL,30H
JBB
的CMP AL,3AH
JNB F
SUB AL,30H
MOV CH,AL的
> MOV AL,BL
MOV BL,0AH
的MUL BL
ADD AL,CH
MOV BL,AL的
。JMP
;的判断+ - * / =
B:的CMP AL,2BH
JNZ MOV X [SI],BL
INC的SI
MOV CL,0H
AND BL, 0
JMPA
K:的CMP AL,2DH
JNZe
MOV X [SI],BL
INC的SI
MOV CL,01H
title>和BL,0 JMPA
D:的CMP AL,2AH
JNZê
MOV X [SI],BL
INC SI
MOV CL,02H
AND BL,0
JMPA
E:的CMP AL,2FH
JNZ
MOV X [的SI],BL
INC的SI
,03H MOV CL
和BL,0
JMPá
;计算
F:MOV [SI],BL
CMP AL,3DH BR /> JNZ
的LEA SI中,X
MOV的AL中,X [SI]
INC的SI
MOV BL中,X [SI]
CMP CL,0 BR /> JNZ
ADD AL,BL
JMP
G:的CMP CL,01H
JNZ SUB AL,BL
JMP J BR /> H:的CMP CL,02H
JNZ我
AND AH,0
的MUL BL
JMP
我:AND AH,0
CMP CL,03H
DIV BL
;输出
J:和AH,0
的CMP AL,100
JB ER
MOV的BL,100
> DIV BL
MOV CL,AH
ADD AL,30H
MOV DL,AL
MOV AH,02H
INT 21H
MOV AL,CL BR /> ER“:●CMP AL,10个
JB毅
MOV BL,10
AND AH,0
DIV BL
ADD AL,30H
MOV DL,AL
MOV CL,AH
MOV的AH,02H
INT 21H
MOV AL,CL
YI“:ADD AL,30H
MOV DL的, AL
MOV的AH,02H
INT 21H
JMP KAISHI
T:LEA的DX,Y。 MOV AH,09H
INT 21H
JMP KAISHI
L:MOV的AH,4CH的
INT 21H
CODES ENDS ”END START“
⑼ 汇编语言的加法运算
这个与具体的硬件有关系,主要是这个输出到屏幕的话···
把结果的每一位十进制数转换成对应的ascii码,传送(mov)到显存去。
具体过程自己去看汇编语言的书去。
再多我也不知道了,或许我比你更年轻。目前大一。
前面的加法倒是超简单,
mov
ax,9
add
ax,1
然后将ax每位对应的ascii码传送到显存去。
⑽ 汇编语言 加法
这个与具体的硬件有关系,主要是这个输出到屏幕的话··· 把结果的每一位十进制数转换成对应的ASCII码,传送(mov)到显存去。 具体过程自己去看汇编语言的书去。 再多我也不知道了,或许我比你更年轻。目前大一。 前面的加法倒是超简单,
mov ax,9
add ax,1
然后将ax每位对应的ASCII码传送到显存去。