news 2026/5/23 19:49:04

malloc底层实现

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
malloc底层实现

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

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

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

不污染堆

避免堆碎片

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/22 13:57:53

【金融项目实战】2_金融项目 _项目介绍(重点)

文章目录 一、项目简介1.1 业务特性1.2 用户1.3 技术架构 二、项目核心业务流程 一、项目简介 1.1 业务特性 xx安享智慧理财项目是一个P2P的金融平台,P2P金融又叫P2P信贷,本项目采用国家政策允许的银行存管模式,为用户提供方便、快捷、安心…

作者头像 李华
网站建设 2026/5/14 15:56:47

阿里双11高并发系统架构设计核心技术全解(2026版)

现在Java面试,问的是越来越底层。作为一名合格的Java程序员不仅要能“上天”,还要能“入地”!上天是指高并发,缓存,大流量,大数据量,能在更高的层面解决问题,入地是指从JVM&#xff…

作者头像 李华
网站建设 2026/5/23 14:19:40

不得了!天玑AIGEO优化系统口碑排行背后的营销奥秘

行业痛点分析在当前天玑AIGEO优化系统领域,存在着诸多技术挑战。对于拥有线下门店或区域化业务的企业而言,精准营销落地困难是一大难题。传统广告投放缺乏数据支撑,难以精准匹配目标客群,导致曝光量分散、转化率低迷,大…

作者头像 李华
网站建设 2026/5/22 10:52:13

Claude Code 完整学习计划

👋 欢迎! 你好!欢迎来到 Claude Code 学习之旅。这份学习计划专门为初学者设计,用最简单、最直白的方式帮你掌握这个强大的 AI 编程助手。 不用担心,我们会一步一步来,保证你能看懂、学会! &a…

作者头像 李华
网站建设 2026/5/17 5:43:01

AI 时代,我们是在进化还是在“脑力外包”?

当代码只剩“一句话”:AI 正在批量杀死程序员,还是在帮我们“脱壳”? 最近技术圈最焦虑的话题,莫过于 AI 程序员。 从 Cursor 的爆火到各种“一句话生成 App”的短视频刷屏,不少同行都在调侃:“以后不用写代码了,直接写小作文吧。”但玩笑归玩笑,深夜关掉编辑器,我们…

作者头像 李华