2023-09-13  阅读(3)
原文作者:https://blog.csdn.net/wangwei19871103/category_9681495_2.html 原文地址: https://blog.csdn.net/wangwei19871103/article/details/104409438

申请缓冲区

今天在来总结下内存分配中的几个主要的角色。这个就是我们用的池化内存分配器,里面会进行很多参数的配置,这些参数的默认值基本也是进行优化过的,如果需要特殊场景,可以进行参数调优,基本是这些参数:

202309132204383201.png
这里要知道,默认是初始化的时候是根据CPU个数*2的数量来进行arena的分区,也就是对应着默认事件循环的个数,每个事件循环会有一个线程,这样避免线程间的竞争,当然如果有其他线程了,也会进行负载均衡的分配,尽可能避免多线程之间的竞争。

202309132204393832.png

创建PoolThreadLocalCache

初始化的时候创建了PoolThreadLocalCache这个线程本地变量,使得每个线程都会有自己独立的线程本地变量对应的值,这个值就是缓存PoolThreadCache

202309132204401753.png

创建PoolThreadCache

然后又创建了PoolArena数组,再创建新的内存空间的时候会先从线程本地变量中获取缓存,如果没有创建缓存,就会进行initialValue初始化,根据PoolArena数组的使用情况,选取使用率最低的PoolArena来创建缓存PoolThreadCache并返回,当然这里如果不使用缓存的话,里面的属性都是默认属性。

202309132204407104.png

获取线程本地变量的PoolArena进行分配

然后在需要创建缓冲区的时候先获取线程本地变量缓存中的PoolArena来分配。

202309132204416355.png

尝试用缓存来分配

当确定好缓冲区需要的容量后,如果容量小于块大小的,先从尝试从缓存中分配:

202309132204426876.png

202309132204438257.png
最终是将缓存中缓存的块信息实体从队列中取出来,重新初始化用。

202309132204449538.png
说到底主要的还是块和句柄,加起来就能定位到起始位置,就可以用了。

202309132204456769.png

缓存分配失败,走正常分配流程

当然如果缓存无法分配就走正常的分配流程,如果是tiny和small类型的,就进行子页的分配,进行位图的记录,最后进行缓冲区的初始化:

2023091322044616010.png

释放缓冲区

释放缓冲区会将缓冲区的块信息放进缓存里,可以给下一个要申请同类型的尺寸的缓冲区。但是如果对应类型的缓冲区放满了,或者没有对应尺寸的缓冲区,那就直接释放了,堆内存交给虚拟机,堆外就直接释放内存。

2023091322044688611.png

创建实体放入队列

放进缓冲区,就是把块信息封装成实体,然后放进队列里。

2023091322044760312.png

释放块

如果放不进缓存,那就会尝试去释放块,如果块的使用率是0了,那就会释放内存。

2023091322044862713.png
释放有子页的:

2023091322044924114.png
真正销毁块:

2023091322045012115.png

2023091322045179016.png

防止内存泄露的措施

netty包装后的任务都会有内存释放,避免内存泄露。

2023091322045223617.png
对应到就是这里:

2023091322045317418.png

2023091322045439919.png
其实大致上的流程还是简单的,只是里面的一些分配的小细节要花时间琢磨,比如伙伴算法分配和回收内存,比如位图记录子页分配信息,如何使用内存映射索引和位图信息来定位分配在块中的起始位置。

好了,今天就到这里了,希望对学习理解有帮助,大神看见勿喷,仅为自己的学习理解,能力有限,请多包涵。


Java 面试宝典是大明哥全力打造的 Java 精品面试题,它是一份靠谱、强大、详细、经典的 Java 后端面试宝典。它不仅仅只是一道道面试题,而是一套完整的 Java 知识体系,一套你 Java 知识点的扫盲贴。

它的内容包括:

  • 大厂真题:Java 面试宝典里面的题目都是最近几年的高频的大厂面试真题。
  • 原创内容:Java 面试宝典内容全部都是大明哥原创,内容全面且通俗易懂,回答部分可以直接作为面试回答内容。
  • 持续更新:一次购买,永久有效。大明哥会持续更新 3+ 年,累计更新 1000+,宝典会不断迭代更新,保证最新、最全面。
  • 覆盖全面:本宝典累计更新 1000+,从 Java 入门到 Java 架构的高频面试题,实现 360° 全覆盖。
  • 不止面试:内容包含面试题解析、内容详解、知识扩展,它不仅仅只是一份面试题,更是一套完整的 Java 知识体系。
  • 宝典详情:https://www.yuque.com/chenssy/sike-java/xvlo920axlp7sf4k
  • 宝典总览:https://www.yuque.com/chenssy/sike-java/yogsehzntzgp4ly1
  • 宝典进展:https://www.yuque.com/chenssy/sike-java/en9ned7loo47z5aw

目前 Java 面试宝典累计更新 400+ 道,总字数 42w+。大明哥还在持续更新中,下图是大明哥在 2024-12 月份的更新情况:

想了解详情的小伙伴,扫描下面二维码加大明哥微信【daming091】咨询

同时,大明哥也整理一套目前市面最常见的热点面试题。微信搜[大明哥聊 Java]或扫描下方二维码关注大明哥的原创公众号[大明哥聊 Java] ,回复【面试题】 即可免费领取。

阅读全文