【学习总结】操作系统(内存布局)

本文详细介绍了操作系统中进程的虚拟内存地址空间布局,包括0x00000000 ~ 0x80048000、0xC0000000 ~ 0xFFFFFFFF等区域的用途。讨论了栈区、堆区、内存映射段、BSS段、数据段和代码段的内容及管理,以及如何通过页表进行地址转换。同时提到了ASLR安全机制,用于防止缓冲区溢出攻击。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

0 概述

进程是操作系统进行资源分配的最小单位,而内存是进程运行必不可少的资源。
现代操作系统为每个进程分配独享的内存空间,这个独享的内存空间只是虚拟内存空间。
每次访问内存空间的某个地址(虚拟地址),都需要把地址翻译成实际物理内存地址。

进程要知道哪些虚拟地址上的数据在物理内存上,哪些不在;还有存放在物理内存上的位置,需要用页表来记录。

正因为每个进程都有一个自己的页表,使得相同的虚拟地址映射到不同的物理内存。每当切换到另一个进程时,就要通过设置MMU的某些寄存器来设置这个进程的页表,然后MMU就可以把CPU发出的虚拟地址转化到物理地址了。
pic

1 虚拟内存地址空间布局介绍

32位模式下它是一个4GB的内存地址块
图: 32 位系统下进程地址空间默认布局(左)和进程地址空间经典布局(右)

  • 每个进程看到的地址空间都是一样的
  • .text 都是从 0x80048000开始
  • 内核地址空间都是 0xC0000000 ~ 0xFFFFFFFF
  • 用户栈都是向低地址增长
  • 堆都是向高地址扩展
1.1 0x00000000 ~ 0x80048000

不能给用户访问,这里面是一些C运行库的内容&

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值