C语言对应的汇编程序

gcc -S  -o main.c -m32

得到汇编程序

把得到的汇编程序中的以点号开头的都是用于链接时候的辅助信息去掉

得到下面干净的汇编程序

 (1)esp:栈指针寄存器(extended stack pointer),其内存放着一个指针,该指针永远指向系统栈最上面一个栈帧的栈顶。
(2)ebp:基址指针寄存器(extended base pointer),其内存放着一个指针,该指针永远指向系统栈最上面一个栈帧的底部,是一个相对的栈底。

其实每个函数 都是一个局部性的栈,下图为函数在内存中的分析

一个函数的开始头两条汇编指令都是一样的。都是先压栈,esp自动增加,将esp拷贝到ebp






### C语言生成的汇编代码示例及解释 对于给定的简单C语言程序: ```c #include <stdio.h> int main(int argc, char* argv[]){ printf("Hello %s!\n", "Richard"); return 0; } ``` 当这段C代码被编译器处理并转化为汇编语言时,其大致形式如下所示。这里展示的是针对x86架构下的GNU/Linux环境中的GCC编译器所生成的部分简化版汇编指令[^1]。 #### 汇编代码片段 ```assembly .global _start _start: sub rsp, 8 ; 调整栈指针以保持16字节堆栈对齐 lea rdi, [rip + .LC0] ; 加载字符串地址到第一个参数寄存器rdi xor eax, eax ; 清零al用于指示printf不使用vector寄存器 call printf ; 调用标准库函数打印消息 mov edi, 0 ; 设置返回值为0 add rsp, 8 ; 恢复栈指针位置 jmp exit ; 结束程序执行 .LC0: .string "Hello Richard!" ``` 上述汇编代码实现了原C源文件的功能需求。具体来说: - `sub` 和 `add` 指令调整了栈顶指针(`rsp`)的位置,确保调用约定所需的正确内存布局。 - 使用 `lea` (Load Effective Address) 将格式化字符串加载到了适当的目标寄存器中准备传递给 `printf`. - 函数调用前清除了AL寄存器的内容 (`xor eax,eax`) ,这是为了告诉运行时系统此调用不需要SSE/AVX支持. - 接下来通过外部链接的方式直接调用了系统的I/O库函数 `printf()` 来显示问候语句. - 最终设置退出状态码并通过跳转至 `_exit` 完成进程终止. 值得注意的是实际产生的汇编可能会更加复杂一些,因为现代编译工具链通常会在多个阶段应用各种优化措施来提高效率或减小程序体积[^2].
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值