栈基础

参考:https://www.52pojie.cn/thread-974510-1-1.html
作者:shavchen


内存四区

  • 代码区(.text):这个区域存储着被装入执行的二进制机器代码,处理器会到这个区域取指令执行。
  • 数据区(.data):用于存储全局变量和静态变量等。
  • 堆区:动态地分配和回收内存,进程可以在堆区动态地请求一定大小的内存,并在用完后归还给堆区。地址由低到高生长。
  • 栈区:用于动态地存储函数之间的调用关系,以保证被调用函数在返回时恢复到母函数中继续执行;此外局部变量也存储在栈区。地址由高到低生长。

BSS段:(bss segment)通常是指用来存放程序中未初始化的全局变量的一块内存区域,属于静态内存分配。


栈的概念

  • 一种数据结构,数据存储方式为先进后出,压栈(push)和出栈(pop).
  • 每个程序都有自己的进程地址空间,进程地址空间中的某一部分就是该程序的栈,用于保存函数调用信息和局部变量.
  • 程序的栈是从进程空间的高地址向低地址增长的,数据是从低地址向高地址存放的

NX保护原理

  • 堆栈不可执行保护,bss段也不可执行,windows下为DEP,可通过gcc -z execstack关闭.

  • 开启NX后再把return的内容覆盖为一段shellcode,在开启NX的时候,不能执行。

     绕过原理 : ROP
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值