
求助 汇编语言 32位*32位 二进制数怎么做乘法??高手帮忙啊~
顺便介绍一下汇编现在的应用方面吧?有人说他淘汰了。。。。有什么好的参考书吗??请顺带留下汇编语言比较好的参考书汇编语言的应用方面能用在嵌入式系统里面吗??会不会在嵌入式方...
顺便介绍一下汇编现在的应用方面吧?有人说他淘汰了。。。。有什么好的参考书吗??
请顺带留下汇编语言比较好的参考书 汇编语言的应用方面 能用在嵌入式系统里面吗??会不会在嵌入式方面被淘汰了? 展开
请顺带留下汇编语言比较好的参考书 汇编语言的应用方面 能用在嵌入式系统里面吗??会不会在嵌入式方面被淘汰了? 展开
展开全部
输入输出的ASC转换我想你是会是,所以就不写了。我只提供32位运算程序。以下程序是试算通过的。
1、在数据段定义4个运算变量
;===============================
;32位运算变量
;===============================
data4 dw ?
data3 dw ?
data2 dw ?
data1 dw ?
2、以下是加、减、乘、除的4个子程序
;*******************************
;32位运算
;*******************************
;===============================
;32位符号数的加法运算
;入: DXAX=32位操作数1
; CXBX=32位操作数2
;出: DXAX=两操作数的和
; OF=1: 溢出
; OF=0: 正常
;===============================
subn_add32 proc near
add ax,bx
adc dx,cx
ret
subn_add32 endp
;===============================
;32位符号数的减法运算
;入: DXAX=32位操作数1
; CXBX=32位操作数2
;出: DXAX=操作数1-操作数2的差
; OF=1: 溢出
; OF=0: 正常
;===============================
subn_sub32 proc near
sub ax,bx
sbb dx,cx
ret
subn_sub32 endp
;===============================
;32位符号数的乘法运算
;入: DXAX=32位操作数1
; CXBX=32位操作数2
;出: CXBXDXAX=两操作数积
;===============================
subn_mul32 proc near
push di
xor di,di
test dh,80h
jz sss_1
mov di,1
not dx
not ax
add ax,1
adc dx,0
sss_1:
test ch,80h
jz sss_2
not cx
not bx
add bx,1
adc cx,0
xor di,1
sss_2:
call subn_32x32
test di,1
jz sss_out
not ax
not bx
not cx
not dx
add ax,1
adc dx,0
adc bx,0
adc cx,0
sss_out:
pop di
ret
subn_mul32 endp
;===============================
;32位符号数的除法运算
;入: DXAX=32位被除数
; CXBX=32位除数
;出:DXAX=商
; CXBX=余数(绝对值)
;===============================
subn_div32 proc near
push di
xor di,di
test dh,80h
jz sss_1
mov di,1
not dx
not ax
add ax,1
adc dx,0
sss_1:
test ch,80h
jz sss_2
not cx
not bx
add bx,1
adc cx,0
xor di,1
sss_2:
call subn_32v32
test di,1
jz sss_out
not ax
not dx
add ax,1
adc dx,0
sss_out:
pop di
ret
subn_div32 endp
;*******以下是内部子程序********
;===============================
;无符号数的32位值乘32位值
;入: DXAX=被乘数
; CXBX=乘数
;出: cx=积的高64位
; bx=积的高48位
; dx=积的高32位
; ax=积的低16位
;===============================
subn_32x32 proc near
push si
push di
mov data1,0
mov data2,0
mov data3,0
mov data4,0
mov si,ax
mov di,dx
mul bx
mov data2,dx
mov data1,ax
mov ax,di
mul bx
add data2,ax
adc data3,dx
mov ax,si
mul cx
add data2,ax
adc data3,dx
adc data4,0
mov ax,di
mul cx
add data3,ax
adc data4,dx
mov cx,data4
mov bx,data3
mov dx,data2
mov ax,data1
pop di
pop si
ret
subn_32x32 endp
;===============================
;无符号数的32位值除以16位值
;入:DXAX=被除数
; CX=除数
;出:DXAX=商
; BX=余数
;===============================
subn_32v16 proc near
push ax
mov ax,dx
mov dx,0
div cx
mov bx,ax
pop ax
div cx
xchg bx,dx
ret
subn_32v16 endp
;===============================
;无符号数的32位值除以32位值
;入:DXAX=被除数
; CXBX=除数
;出:DXAX=商
; CXBX=余数
;===============================
subn_32v32 proc near
test cx,cx
jnz sss_1
mov cx,bx
call subn_32v16
xor cx,cx
ret
sss_1:
push di
xor di,di
sss_lp1:
sub ax,bx
sbb dx,cx
jc sss_out
inc di
jmp sss_lp1
sss_out:
add bx,ax
adc cx,dx
mov ax,di
mov dx,0
pop di
ret
subn_32v32 endp
汇编在PC上用的是少了,除了逆向工程,软件加解密这些。
学习汇编能够更好的理解高级语言。
王爽(汇编语言)
1、在数据段定义4个运算变量
;===============================
;32位运算变量
;===============================
data4 dw ?
data3 dw ?
data2 dw ?
data1 dw ?
2、以下是加、减、乘、除的4个子程序
;*******************************
;32位运算
;*******************************
;===============================
;32位符号数的加法运算
;入: DXAX=32位操作数1
; CXBX=32位操作数2
;出: DXAX=两操作数的和
; OF=1: 溢出
; OF=0: 正常
;===============================
subn_add32 proc near
add ax,bx
adc dx,cx
ret
subn_add32 endp
;===============================
;32位符号数的减法运算
;入: DXAX=32位操作数1
; CXBX=32位操作数2
;出: DXAX=操作数1-操作数2的差
; OF=1: 溢出
; OF=0: 正常
;===============================
subn_sub32 proc near
sub ax,bx
sbb dx,cx
ret
subn_sub32 endp
;===============================
;32位符号数的乘法运算
;入: DXAX=32位操作数1
; CXBX=32位操作数2
;出: CXBXDXAX=两操作数积
;===============================
subn_mul32 proc near
push di
xor di,di
test dh,80h
jz sss_1
mov di,1
not dx
not ax
add ax,1
adc dx,0
sss_1:
test ch,80h
jz sss_2
not cx
not bx
add bx,1
adc cx,0
xor di,1
sss_2:
call subn_32x32
test di,1
jz sss_out
not ax
not bx
not cx
not dx
add ax,1
adc dx,0
adc bx,0
adc cx,0
sss_out:
pop di
ret
subn_mul32 endp
;===============================
;32位符号数的除法运算
;入: DXAX=32位被除数
; CXBX=32位除数
;出:DXAX=商
; CXBX=余数(绝对值)
;===============================
subn_div32 proc near
push di
xor di,di
test dh,80h
jz sss_1
mov di,1
not dx
not ax
add ax,1
adc dx,0
sss_1:
test ch,80h
jz sss_2
not cx
not bx
add bx,1
adc cx,0
xor di,1
sss_2:
call subn_32v32
test di,1
jz sss_out
not ax
not dx
add ax,1
adc dx,0
sss_out:
pop di
ret
subn_div32 endp
;*******以下是内部子程序********
;===============================
;无符号数的32位值乘32位值
;入: DXAX=被乘数
; CXBX=乘数
;出: cx=积的高64位
; bx=积的高48位
; dx=积的高32位
; ax=积的低16位
;===============================
subn_32x32 proc near
push si
push di
mov data1,0
mov data2,0
mov data3,0
mov data4,0
mov si,ax
mov di,dx
mul bx
mov data2,dx
mov data1,ax
mov ax,di
mul bx
add data2,ax
adc data3,dx
mov ax,si
mul cx
add data2,ax
adc data3,dx
adc data4,0
mov ax,di
mul cx
add data3,ax
adc data4,dx
mov cx,data4
mov bx,data3
mov dx,data2
mov ax,data1
pop di
pop si
ret
subn_32x32 endp
;===============================
;无符号数的32位值除以16位值
;入:DXAX=被除数
; CX=除数
;出:DXAX=商
; BX=余数
;===============================
subn_32v16 proc near
push ax
mov ax,dx
mov dx,0
div cx
mov bx,ax
pop ax
div cx
xchg bx,dx
ret
subn_32v16 endp
;===============================
;无符号数的32位值除以32位值
;入:DXAX=被除数
; CXBX=除数
;出:DXAX=商
; CXBX=余数
;===============================
subn_32v32 proc near
test cx,cx
jnz sss_1
mov cx,bx
call subn_32v16
xor cx,cx
ret
sss_1:
push di
xor di,di
sss_lp1:
sub ax,bx
sbb dx,cx
jc sss_out
inc di
jmp sss_lp1
sss_out:
add bx,ax
adc cx,dx
mov ax,di
mov dx,0
pop di
ret
subn_32v32 endp
汇编在PC上用的是少了,除了逆向工程,软件加解密这些。
学习汇编能够更好的理解高级语言。
王爽(汇编语言)
参考资料: http://zhidao.baidu.com/question/54627327.html?si=4
2009-04-03
展开全部
嵌入式系统?先从8051单片机看起吧,然后可以学AVR。
汇编主要用在效率要求较高的实时控制部分。其他部分C语言可以解决。C和汇编混编的方式至少在20年内不会被淘汰。
汇编主要用在效率要求较高的实时控制部分。其他部分C语言可以解决。C和汇编混编的方式至少在20年内不会被淘汰。
参考资料: 80年代的老书不错的,图书馆有。现在的书,唉~~
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
去 汇编网 看王爽老师的《汇编语言》论坛里有下的,那个论坛是学汇编最好的去处。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询