Glibc 的 Malloc 有时候不会把 free 的内存还给 OS,有趣的发现

2023-02-08 05:39:23 +08:00
 dangyuluo

假设我们对 Glibc malloc 和 free 的实现一无所知,malloc 了一大堆内存后在挨个 free 掉,会发现 free 的顺序实际上决定是否将内存返回给 OS ,看最后一个system bytes

下一步是读 malloc 的源码,估计是用一个 linked list 来管理 heap 内存的

1603 次点击
所在节点    C
3 条回复
tyzandhr
2023-02-08 06:09:45 +08:00
不是新发现了。建议用 tcmalloc
nopnewbie
2023-02-08 09:32:17 +08:00
嗯,现在你已经学会 ptmalloc2 的源码了,那么你就可以就来做几道 glibc heap overflow 的 pwn 吧。
bfdh
2023-02-08 09:58:57 +08:00
内存空洞

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/914123

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX