首页 / LINUX / linux – 堆管理
linux – 堆管理
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了linux – 堆管理,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1437字,纯文字阅读大概需要3分钟。
内容图文
![linux – 堆管理](/upload/InfoBanner/zyjiaocheng/968/8f6ec0d429d440bbabb06011257248c0.jpg)
我知道有一个元数据存储辅助信息,当我们只提供指针时,它会在free(),realloc()期间使用.
我对堆很少有疑问.
>堆栈按进程分配.毫无疑问,但不确定堆.无论堆信息是否全局维护,否则每个进程都会有一些机制来保存有关该特定进程的已分配内存的信息.
>如何维护堆信息?我猜哈希机制.我用Google搜索并尝试了SO.他们中的大多数人都将其解释为具体实施……就像那样.
解决方法:
像堆栈一样,堆是一个进程,一个(几乎)纯粹的用户空间.
堆管理器使用sbrk系统调用通知操作系统它打算增加所需的内存量.除了将“未知”到“现有,零,从未访问”的页面范围更改之外,这几乎没有什么(这实际上意味着它们仍然不存在,但操作系统假装它们会这样做).首次访问页面时,它会出现故障,并且操作系统会从零池中提取零页面.
(它可能稍微复杂一些,因为如果从顶部释放了大量内存,堆管理器也可能缩小数据段,但基本上它就像那样简单).
这已经是所有操作系统都知道堆的了.其他所有内容,例如拆分块,将释放的块放入列表或类似结构,以及重用块都发生在堆管理器内,这是直接或间接(例如作为glibc的一部分)程序的一部分.
堆管理器究竟在做什么是依赖于实现的,至少存在六种众所周知的不同malloc实现,它们以不同的方式工作.参见例如this one或this one或this one.
堆栈以相同或类似的方式工作.某个内存范围最初是“保留的”,而不实际保留任何内容(即,不创建页面).提交了几个页面(即创建),最后一页是写保护或不存在的,这是以特殊方式记住的.当堆栈增长以触及最后一页时,就会发生故障.然后,如果堆栈仍在允许的大小范围内,则从零池中提取新页面.
当进程终止时,对这些页面的所有引用都将被删除,并且(假设它们不与仍保留引用的另一个进程共享)移交给低优先级后台任务,后者将它们归零并将它们添加到“零池”.
内容总结
以上是互联网集市为您收集整理的linux – 堆管理全部内容,希望文章能够帮你解决linux – 堆管理所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。