汇编语言 子程序设计
作者:互联网
1.编写一个求n!的子程序,利用它求1!+2! +3! +4! +5! +6! +7! +8! 的和(=46233 )并输出。要求参数的传递分别采用:寄存器传递、全局变量传递,堆栈传递三种不同的方法实现。
代码
; 寄存器传参
include io32.inc
.data
sum dword 0
.code
start:
main proc
mov ebx, 1
.while ebx <= 8
call fac
add sum, eax
inc ebx
.endw
mov eax, sum
call dispuid
call dispcrlf
ret
main endp
fac proc
mov ecx, 1
mov eax, 1
.while ecx <= ebx
imul eax, ecx
inc ecx
.endw
ret
fac endp
end main
截图
2. 编写一个判断闰年的子程序,利用它求出2010年到2060年之间所有的闰年并输出。建议采用堆栈传递参数。
代码
include io32.inc
.data
year dword ?
flag dword ?
.code
main proc
mov year, 2010
.while year <= 2060
call leap
cmp flag, 1
jne next
mov eax, year
call dispuid
call dispcrlf
next: inc year
.endw
main endp
leap proc
mov flag, 0
mov eax, year
xor edx, edx
push eax
push edx
mov ebx, 400
div ebx
.if !edx
jmp lab1
.else
pop edx
pop eax
mov ebx, 4
div ebx
.if !edx
mov eax, year
xor edx, edx
mov ebx, 100
div ebx
.if edx
jmp lab1
.else
jmp lab2
.endif
.else
jmp lab2
.endif
.endif
lab1:
mov flag, 1
lab2:
ret
leap endp
end main
截图
3. 编程写一个名为Prime的子程序,用于测试一个整数是否是素数,主子程序间的参数传递通过堆栈完成。调用Prime子程序求出2~100之间的所有素数,并将它们存入Parray数组中,素数的个数存入变量Pcounter中。
代码
include io32.inc
.data
Parray dword 100 dup(0)
flag dword ?
.code
main proc
mov esi, offset Parray ; ESI 为指向 array 数组首地址的指针
mov ebx, 2
.while ebx <= 100
push ebx
call Prime
.if flag == 1
mov [esi], ebx
add esi, 4
; show1
mov eax, ebx
call dispuid
call dispcrlf
.endif
inc ebx
.endw
; show2
;mov ecx, lengthof Parray
;mov ebx, offset Parray
;again:
;mov eax, [ebx]
;.if eax == 0
; ret
;.endif
;call dispuid
;call dispcrlf
;add ebx, 4
;loop again
ret
main endp
Prime proc
push ebp
mov ebp, esp
; 求素数的核心程序
mov ecx, 2
.while ecx < [ebp + 8]
;.if [ebp + 8] % ecx == 0
mov eax, [ebp + 8]
mov edx, 0
div ecx
.if edx == 0
mov flag, 0
jmp done
.endif
inc ecx
.endw
mov flag, 1
done:
pop ebp
ret 1 * 4
Prime endp
end main
截图
4. 编程写一个名为Gcd的求两个数最大公约数子程序,主子程序间的参数传递通过堆栈完成。调用Gcd子程序求出三个双字变量:dvar1、dvar2与dvar3的最大公约数并输出。
代码
include vcIO.inc
.data
prompt byte '请输入三个整数(以空格分隔):', 0
fmt1 byte '%d %d %d', 0
fmt2 byte '最大公约数:%d', 13, 10, 13, 10, 0
dvar1 dword ?
dvar2 dword ?
dvar3 dword ?
res dword ?
.code
main proc
again:
pushad
invoke printf, offset prompt
invoke scanf, offset fmt1, offset dvar1, offset dvar2, offset dvar3
popad
push dvar1
push dvar2
call gcd ; 堆栈传参,结果保存在 EAX
add esp, 8
push eax
push dvar3
call gcd
add esp, 8
mov res, eax
pushad
invoke printf, offset fmt2, res
popad
jmp again
ret
main endp
gcd proc
push ebp
mov ebp, esp
push ebx ; 保护寄存器
push edx
mov eax, [ebp + 8]
mov ebx, [ebp + 12]
.if eax < ebx
xchg eax, ebx
.endif
.while ebx != 0
xor edx, edx
idiv ebx
mov eax, edx
xchg eax, ebx
.endw
pop edx
pop ebx
pop ebp
ret
gcd endp
end main
截图
5. 编写一子程序,将一个32位二进制数用8位十六进制形式在屏幕上显示出来。采用堆栈方法传递这个32位二进制数,并写主程序验证它。显示一个字符的子程序为:dispc,入口参数:AL=要显示个字符的SACII码。
代码
include io32.inc
.data
msg1 byte '32位二进制:00110000011100101000000110101111B', 13, 10, 0
msg2 byte '8位十六进制:', 0
dvar dword 00110000011100101000000110101111B
.code
main proc
mov eax, offset msg1
call dispmsg
mov eax, offset msg2
call dispmsg
push dvar
call disp
mov al, 'H'
call dispc
call dispcrlf
ret
main endp
disp proc
push ebp
mov ebp, esp
push ecx
mov ecx, 8
mov eax, [ebp + 8]
again: rol eax, 4
push eax
and al, 0fh
add al, 30h
.if al > '9'
add al, 7
.endif
call dispc
pop eax
loop again
pop ecx
pop ebp
ret 1 * 4
disp endp
end main
截图
6. 编程写一个名为Bubble的冒泡排序子程序,主子程序间的参数传递通过堆栈完成;并写主程序验证它。
代码
; BubbleSort
include vcIO.inc
include io32.inc
.data
array dword 3, 2, -1, 3, 5
msg1 byte '原数组:', 0
msg2 byte '新数组:', 0
len dword lengthof array
fmt byte '%d ', 0
.code
main proc
mov eax, offset msg1
call dispmsg
call show
call bubbleSort
mov eax, offset msg2
call dispmsg
call show
ret
main endp
show proc
push ebp
mov ebp, esp
push ebx
pushad
mov ebx, 0
.while ebx < len
invoke printf, offset fmt, array[ebx * 4]
inc ebx
.endw
popad
call dispcrlf
pop ebx
pop ebp
ret
show endp
bubbleSort proc
push ebp
mov ebp, esp
push eax
push ebx
push esi
push edi
mov esi, 0
.while esi < len
mov edi, esi
inc edi
mov eax, array[esi * 4]
.while edi < len
mov ebx, array[edi * 4]
.if sdword ptr eax > sdword ptr ebx
xchg eax, ebx
mov dword ptr array[esi * 4], eax
mov dword ptr array[edi * 4], ebx
.endif
inc edi
.endw
inc esi
.endw
pop edi
pop esi
pop ebx
pop eax
pop ebp
ret
bubbleSort endp
end main
截图
看后点赞,好运不断
标签:call,汇编语言,mov,eax,ebp,push,程序设计,ebx 来源: https://blog.csdn.net/qq_46105528/article/details/117198753