汇编语言程序设计(二)十六位汇编框架、子程序与堆栈

寄存器

如下是16位通用寄存器,存储在cpu硬件中

AX 返回值

AX寄存器分为两部分 AH和AL

AH 高8位 存储功能号

AL 低8位 存储返回码

以下是一个AX寄存器应用:

mov ax,4c00h 4c给高位AL,00低位AL,16进制要以h结尾

BX

CX 计数器

DX

SI 目标寄存器

DI 源寄存器

SP 栈顶指针寄存器

BP 栈底指针寄存器

16位堆栈每单元占2字节

常见编译器指令

r 查看寄存器及下一行的指令

u 查看汇编代码

t 单步步入 遇见子程序进入内部 遇到int 21h指令时不要用t

p 单步步过 遇见子程序执行到子程序的下一行,忽略子程序的内部实现

g 运行

q 退出

d 读内存

d ss:fffe 0700 0007

常见汇编指令

MOV 数据传送指令 :

格式:MOV OPRD1,OPRD2 用处是将操作数2的值放到操作数1中

OPRD1指寄存器,内存

OPRD2指寄存器,内存,立即数即12345

内存(即变量)存储在内存中

以下是一个该指令应用例子:

MOV ax,1 将立即数1传入寄存器ax中

start 指定主程序起始位置

end start 指定主程序结束位置

proc 函数头

endp 函数尾

ret 函数返回:

在堆栈顶部取出返回地址,并且放置到IP寄存器

跳转到IP寄存器所在位置

jmp 无条件跳转指令:

jmp addr addr是地址,地址指哪跳转哪

call 子程序调用:

保存返回地址到堆栈

跳转到子程序中

int (中断指令):

最常见的中断指令 int 3,硬编码0xcc,称作软件中断

结束汇编程序需要DOS系统中int 21h指令,也叫21号中断,它具有很多功能。其中一个功能4C,

用来实现程序退出、并返回DOS。使用方法如下:

mov ah, 4ch

int 21h 此时中断程序

函数调用实现

参数:可以用内存,堆栈,寄存器传递参数

16位堆栈每单元占2字节,32位堆栈每单元占4字节,64位堆栈每单元占8字节

程序要时刻保持堆栈平衡

在传参时:

push 将一个值或者地址压入栈中,之后sp-2(如果是32位处理器-4)

pop 将一个值或者地址弹出栈中,之后sp+2(如果是32位处理器+4)

pop也可以换成add sp,2,意思是将栈屏掉2个字节,此时不需要管栈中的数据

返回值默认放在ax,eax,rax里

一个汇编程序

assume cs:code code表示cs段的起始位置,cs段就是代码段

code segment 代码段开始

setAx proc 函数开头

push bp

mov bp,sp

mov si,[bp+4]

mov di,[bp+6] 利用bp寻址

mov ax,0ffffh 如果数据都是字母时, 开头0声明他是一个数字,h结尾表示他是一个十六进制数字

pop bp

ret 函数返回

setAx endp 函数结束

start: 程序开始

mov ax,4

mov bx,5

push ax

push bx 将寄存器中数据压入栈中

call setAx 调用子程序即函数

add sp,4 将栈屏掉4个字节用于平栈

mov ax,1 将1放到ax寄存器保存

mov bx,2

mov ax,4c00h 将4c00传给ax寄存器

int 21h 触发中断

code ends 代码段的结束位置

end start 结束程序

相关推荐
阿昭L10 小时前
计算机外设与CPU通信
汇编·计算机外设
wyiyiyi1 天前
【数据结构+算法】进栈顺序推算、卡特兰数与逆波兰表达式
汇编·数据结构·笔记·算法
white-persist1 天前
汇编代码详细解释:汇编语言如何转化为对应的C语言,怎么转化为对应的C代码?
java·c语言·前端·网络·汇编·安全·网络安全
CC-NX1 天前
32位汇编:实验9分支程序结构使用
汇编·算法·win32·分支结构
花阴偷移3 天前
逆向基础--汇编基础(字与物料地址) (004)
汇编
小尧嵌入式3 天前
STM32启动汇编文件详解及启动逻辑
汇编·arm开发·stm32·单片机
花阴偷移3 天前
逆向基础--汇编基础(CS与IP) (05)
网络·汇编·网络协议·tcp/ip
梓仁沐白8 天前
CSAPP实验2:Bomb
汇编
资料,小偿9 天前
8086微机原理与汇编语言,8086程序设计,EMU8086,MASM,汇编程序设计,proteus
汇编·51单片机·proteus
rechol19 天前
汇编与底层编程笔记
汇编·arm开发·笔记