美文网首页
十五.函数本质之04总结

十五.函数本质之04总结

作者: mkb2 | 来源:发表于2017-05-20 10:44 被阅读51次
将cc填充,比价安全,覆盖过去的所有的东西 将局部变量分配的内存空间,全部设置成CC,容错
; 函数的调用流程
; 1.push参数
; 2.将函数的返回地址入栈(下一条指令的地址)
; 3.保护bp,将sp赋值给bp       
; 4.分配一定的空间给局部变量使用(让sp减去空间大小),为了安全并使用CC填充(int 3h) 
; 5.保护可能被业务代码修改的一些寄存器
; 6.具体的业务代码
; 7.恢复寄存器的值(跟第5步相反)  
; 8.将bp赋值给sp,恢复bp 
; 9.返回(ret)

所有代码

assume cs:code, ds:data, ss:stack 

; 栈段(存放数据,比如高级语言中的局部变量)
stack segment     
    db 200 dup(0)            
stack ends  

; 数据段(存放数据,比如高级语言中的全局变量)
data segment       
    db 20 dup(0)  
    string db 'Hello World!$'                
data ends     

; 代码段
code segment            
start:     
    ; 设置ds、ss的值
    mov ax, data
    mov ds, ax 
    mov ax, stack
    mov ss, ax      
    
    mov cx, 8h
    
    ; 业务逻辑  
    push 3h    
    push 4h   
    call sum  
    
    mov dx, cx 
                
    ; 退出程序
    mov ah, 4ch
    int 21h

; 参数:传递3个字型参数,参数放到栈中 
; 返回值:返回值存放到ax中 
sum: 
    ; 保护bp
    push bp          
    mov bp, sp
    sub sp, 20 ; 20字节留作局部变量的空间 
    
    ; 保护寄存器
    push bx
    push cx
    push dx
    
    ; 用int 3填充局部变量空间
    ;lea di, [bp - 20]
    ;mov cx, 10
    ;mov ax, 0cccch    
    ;mov bx, ss
    ;mov es, bx
    ;rep stosw  
    
    ;******** 业务逻辑代码 begin ********
    ; 取出参数 
    ; 定义一个局部变量的值是1
    mov ss:[bp - 2], 1h    
    ; 定义一个局部变量的值是2
    mov ss:[bp - 4], 2h 
    
    ; 修改了寄存器
    mov bx, 2h
    mov cx, 3h
    mov dx, 4h   
    
    ; 将外面传递进来的2个参数和2个局部变量相加,存储到ax中作为返回值
    mov ax, ss:[bp+2]
    add ax, ss:[bp+4] 
    add ax, ss:[bp - 2]     
    add ax, ss:[bp - 4]
    ;******** 业务逻辑代码 end ******** 
    
    ; 恢复寄存器
    pop dx         
    pop cx
    pop bx
    
    ; 恢复sp
    mov sp, bp
    ; 恢复bp
    pop bp
    
    ret 4       
     
code ends    

end start 
最终调用完毕函数,依旧实现了站平衡,不要执行完毕一个函数之后,突然少了一截内存,那就废了

相关文章

  • 十五.函数本质之04总结

    所有代码

  • 指针扫盲

    一.函数指针与指针函数 总结函数指针, 本质上它是一个指针,这个指针指向一个函数地址指针函数,本质上它是一个函数,...

  • iOS逆向之函数本质总结

    栈 1.是一种具有特殊的访问方式的存储空间(后进先出,Last In Out firt,LIFO) 2.s...

  • ES6之Class跟普通构造函数

    构造函数 Class构造函数 class的本质还是函数 Class 继承 总结 class更加贴近于面向对象的写法...

  • 2018-08-30 day9- 函数

    总结 一.匿名函数 匿名函数本质还是函数,之前函数的所有内容都适用于它 1.匿名函数的声明 函数名 = lambd...

  • 2019-04-12(反思)

    《2019年04月12日》 【连续第256+1+1+2+3+1+153天总结】 互联网的本质? 电商的本质? 电商...

  • 2019-04-10(本质)

    《2019年04月10日》 【连续第256+1+1+2+3+1+151天总结】 本质是什么东西?为什么要抓他?本质...

  • 机器学习实战-学习笔记

    AiLearning之机器学习基础总结 Logsitic回归 sigmoid阶跃函数: Tanh函数:sigmoi...

  • 前端_JavaScript

    JavaScript 专题之惰性函数 JavaScript 专题系列第十五篇,讲解惰性函数 需求 我们现在需要写一...

  • 2019-04-11(概念与本质)

    《2019年04月11日》 【连续第256+1+1+2+3+1+152天总结】 抓本质需要长期训练,训练方法是通过...

网友评论

      本文标题:十五.函数本质之04总结

      本文链接:https://www.haomeiwen.com/subject/kaouxxtx.html