详解汇编cll ret push pop 并附源码

一.call 实际上做了两次操作

1.push eip+1,(不能这么写)保存返回地址

2.jmp 跳转到函数

二.ret 实际上做了两次操作和call

1.pop eip(不能这么写),取出返回的地址

  1. jmp 跳转到pop取出来的地址

三.push rbp 开辟栈帧 做了两步操作

1.sub esp,4

2.mov ptr[esp] ebp

四.pop rbp 释放栈帧

1.mov ebp,ptr[esp]

2.add esp,4

五.源码

1.调用函数

复制代码
       push 10
       push 5
       push re;call 两步1:push rip+1(这个+1是下一步 不是地址偏移) 2jmp
       jmp fun
re:    
       sub esp,4
       mov dword ptr[ebp-12],eax
       invoke printf,ADDR format,dword ptr[ebp-12] ;调用printf函数

2.函数实现

复制代码
fun:
        push ebp;push 两步 sub eps,4(esp偏移4个字节) mov [esp],ebp(保存当前ebp)
        mov  ebp,esp
        sub  esp,4
        mov  dword ptr[ebp-4],0
        ;mov  dword ptr[ebp - 8], 1
        jmp  s1
        s3:
        add  dword ptr[ebp + 8],1
        s1:
        mov  ecx,dword ptr[ebp +12]
        cmp  dword ptr[ebp +8], ecx
        jge  s2;如果左边大于等于右边跳出循环

        mov  eax,dword ptr[ebp +8]
        mov  ebx, dword ptr[ebp +12]
        imul eax,ebx
        mov  dword ptr[ebp - 4],eax
        ;invoke printf,ADDR format1,dword ptr[ebp - 4] ;调用printf函数
        jmp  s3

        s2:
        mov eax,dword ptr[ebp-4]
        mov  esp,ebp
        mov ebp,dword ptr[esp];pop 就是以下两步
        add esp,4

        ret;ret 两步1:pop rip(这个+1时下一步不是地址偏移) 2jmp
相关推荐
郝学胜-神的一滴19 分钟前
深入解析Linux网络编程之bind函数:从基础到实践的艺术
linux·服务器·网络·c++·websocket·程序人生
雾岛听蓝28 分钟前
C++11 列表初始化与右值引用核心解析
开发语言·c++·经验分享
痴儿哈哈38 分钟前
C++与硬件交互编程
开发语言·c++·算法
来自晴朗的明天44 分钟前
2、NMOS 电源防反接电路
单片机·嵌入式硬件·硬件工程
闻缺陷则喜何志丹1 小时前
【栈 递归】P8650 [蓝桥杯 2017 省 A] 正则问题|普及+
c++·数学·蓝桥杯·递归·
苏宸啊1 小时前
vecto底层模拟实现
c++
一切尽在,你来1 小时前
C++多线程教程-1.2.2 C++标准库并发组件的设计理念
开发语言·c++
m0_561359671 小时前
代码热更新技术
开发语言·c++·算法
兩尛2 小时前
c++知识点1
java·开发语言·c++
冉佳驹2 小时前
C++11 ——— 列表初始化、移动语义、可变参数模板、lamdba表达式、function包装器和bind包装器
c++·可变参数模板·移动构造·移动赋值·function包装器·bind包装器·lamdba表达式