首页投稿(暂停使用,暂停投稿)架构算法设计模式和编程理论程序员

虚拟内存

2017-01-16  本文已影响191人  初心不渝

一, 内存结构描述

1. 查看进程

内存分配结构

2. 内存分配

3.new 与 malloc

4.函数调用栈空间的分配与释放

二, 虚拟内存

每个应用程序在启动时, 并没有直接访问内存的物理地址. 而是通过虚拟内存映射的方式向物理内存申请存储空间. 对于Linux 系统而言, 每个程序的起始的虚拟地址都是 0x80084000.

1. 虚拟内存映射

应用程序在运行的过程中所使用的地址并不是物理地址, 而是逻辑地址(虚拟内存). 对于逻辑地址, 不过是一个整形数据而已. 如果对int型分配的是4个字节. 那么32位的寻址方位刚好是4G, 十六进制表示0x1000. 我们将这个数值成为一个页.

2. 虚拟内存分配

虚拟内存映射

从上面的内存分配结构图中, 我们可以看到, 系统分配内存都是 1 个页 或 1个页的整数倍. 每个程序在运行的时候, 都会在物理内存上有自己的映射. 一旦访问没有映射的物理内存区域, 程序就会出现崩溃.

3. brk 和sbrk

void* sbrk(int size)

sbrk 可以用来分配空间, sbrk(0) 第一次运行时, 我们通常用来获取没有映射的空闲空间的首地址. 与malloc 不同, malloc维护的是一个结构体, 而sbrk维护的是一个整形的指针.

int brk(void* end)

brk用来分配空间和释放空间.

sbrk 操作的是绝对位置, brk操作的是相对位置.
sbrk 常用来获取地址, brk常用来分配空间. 两者搭配使用.

上一篇 下一篇

猜你喜欢

热点阅读