malloc底层实现

malloc 本质是一个"用户态内存管理器" 它向操作系统批量要内存brk / mmap),然后在用户态 把这些内存切块、复用、合并、回收

从你调用 malloc 开始发生了什么?

cpp 复制代码
void* p = malloc(100);

真实流程大概是:

**malloc(100)

glibc 的 ptmalloc

  1. 在进程已有的堆中找合适的空闲块
  2. 找不到 → 向 OS 申请新内存
    ├─ 小块:brk 扩展堆
    └─ 大块:mmap 映射匿名内存**

重点
malloc 不是每次都系统调用,绝大多数是用户态完成的。

进程的"堆"长什么样?

低地址
┌────────────┐
│ text/code │
├────────────┤
│ data/bss │
├────────────┤
│ heap │ ← brk 向上增长
│ │
├────────────┤
│ ... │
├────────────┤
│ stack │ ← 向下增长
└────────────┘
高地址

heap 是 malloc 主要活动区域

brk() / sbrk() 扩展

连续虚拟地址

glibc malloc 的核心实现:ptmalloc

Linux 下默认是 ptmalloc

目标 解释
尽量 O(1)
少碎片 合并、分级
多线程友好 arena
减少系统调用 批量申请

malloc 管理的"内存块"结构

┌───────────────────────┐
│ prev_size (可选) │
├───────────────────────┤
│ size | flags │ ← 是否空闲 / mmap
├───────────────────────┤
│ 用户数据区 │ ← malloc 返回的指针
│ │
├───────────────────────┤
│ (空闲时) fd / bk │ ← 双向链表指针
└───────────────────────┘

size 字段里藏了"位标志"

size = 实际大小 | PREV_INUSE | IS_MMAPPED | ...
malloc 能 O(1) 合并相邻 free 块,靠的就是这些 flag。

free 链表 & bin 体系

glibc 用 多级 bin 管理不同大小的内存块。

fastbin

很小的内存(≤ 64B 左右)

单向链表 free

不合并,直接塞进去

极快,但容易产生碎片

small bin

精确大小分类

双向链表

free 时可以合并

large bin(大块)

按大小范围分

近似 best-fit

适合 1KB~128KB

unsorted bin

所有 free 的块先放这里

复制代码
free()
  ↓
unsorted bin
  ↓
malloc 时再决定进哪个 bin
减少 bin 操作开销

malloc 的查找策略

malloc(n) 的步骤

malloc(n) 的步骤

对齐 + 最小块大小修正

优先查:

fastbin

small bin

找不到:从 unsorted bin 拆

还没有:

large bin

再不行:

向 OS 要内存

什么时候用 brk?什么时候用 mmap?

申请大小 方式
小块 brk(堆)
大块 mmap

mmap 的特点

独立虚拟内存区

free 直接 munmap

不污染堆

避免堆碎片

相关推荐
做cv的小昊13 小时前
【TJU】应用统计学——第四周作业(2.3 C-R不等式、2.4区间估计)
c语言·人工智能·算法·机器学习·数学建模·r语言·概率论
Liangwei Lin13 小时前
洛谷 P2895 [USACO08FEB] Meteor Shower S
数据结构·算法
计算机安禾13 小时前
【数据结构与算法】第26篇:静态查找(二):插值查找与斐波那契查找
c语言·开发语言·数据结构·学习·算法·重构·visual studio
小年糕是糕手13 小时前
【35天从0开始备战蓝桥杯 -- Day8】
数据结构·c++·算法·leetcode·蓝桥杯
小辉同志13 小时前
39. 组合总和
c++·算法·力扣·剪枝·回溯
ZhouDevin13 小时前
【算法实战】DEIMv2全流程复现
人工智能·python·算法·目标检测·计算机视觉·transformer
汀、人工智能13 小时前
[特殊字符] 第8课:盛最多水的容器
数据结构·算法·数据库架构·图论·bfs·盛最多水的容器
灰色小旋风13 小时前
力扣两两交换链表中的结点C++
数据结构·c++·算法·leetcode
We་ct13 小时前
LeetCode 136. 只出现一次的数字:线性时间+常量空间最优解拆解
前端·算法·leetcode·typescript·位运算
tankeven13 小时前
HJ161 走一个大整数迷宫
c++·算法