当前位置:首页 > 每日看点 > 正文内容

Ja协程的引入会导致GCRoot枚举复杂度大大增加,JVM是如何解决的呢?

卡卷网10个月前 (01-10)每日看点164

<>Ja协程与GC的爱恨情仇-JVM是如何化解性能危机的?

<>GC本是好好工作,但协程的加入,却让它卷入了一场复杂的性能考验。不过,JVM团队也给出了解决方案,化繁为简,让这对“矛盾CP”握手言和。

<>协程和GC:从爱到“恨”到底发生了什么?

<>GC是如何工作的?

GC(回收器)的核心任务,是清理掉不再使用的对象,释放内存。但在清理之前,GC必须完成一个重要步骤:<>GCRoot枚举,也就是找到程序中所有活跃的引用起点,如:

    <>线程栈帧的局部变量。<>静态变量(全局引用)。<>JNI方法中的本地引用。

传线程中,线程栈是连续的,GC只需扫描每个线程的栈帧即可搞定。<>但是,协程的加入让一切变复杂了!

<>协程的问题在哪?

协程的魅力在于<>挂起和恢复:你可以暂停一个协程,保存当前状态(包括栈帧),稍后在另一个线程上恢复它。问题是,协程的栈帧可能<>脱离线程栈:挂起的协程会把栈帧移到堆中(对,放到GC负责的地方!)。另外协程是<>分散保存的,协程的状态可以被调度器和内存存储,这让GC很难找到所有相关引用。

就像你在图书馆整理书籍(对象),突然有上千个图书员(协程)抱着书四处跑,还随手把书进书架。这对GC来说,简直就是噩梦!

<>JVM是怎么样化解协程与GC的矛盾的?

JVM团队展示了一种很巧妙的设计,可以用几个来概括:

<>1.[断点续传]:精确掌控协程的挂起与恢复

协程可以在任意挂起点暂停,但JVM的Safepoint(安全点)可以帮助GC实时跟踪这些挂起点的位置,就像你看剧时按下的暂停键。具体实现方式包括协程挂起时,<>保存当前栈帧到堆,让GC继续枚举时可以直接从堆访问。以及Safepoint确保挂起作与GC同步,让GC的枚举总是精准无误。

<>通俗点讲:JVM为协程配备了“暂停记录仪”这个神器,无论你在哪里停下,它都能找到你。

<>2.[分批处理]:避免一次性扫描的压力

面对成千上万的协程栈帧,JVM并不会“一股脑全扫完”,而是采用了<>分批处理的策略:

    GC枚举协程栈帧时,会将所有协程分成多个批次,每次处理一个小批量,防止因为协程数量过多导致性能瓶颈。如果处理时间超过设定的阈值(如50ms),GC会暂停并等待下一轮回收。

用伪代码可以这样理解:

for(atch:splitInatches(allCoroutines)){ processatch(atch); if(timeExceeded()){ pause(); continue; } }

这就像图书馆员一次只整理几排书,而不是试图瞬间整理整座图书馆。

<>3.[共享栈]:让协程更轻更快

VirtualThread(虚拟线程)是Ja的最后防线,为了减少内存开销,JVM不为每个协程分配的栈,而是采用<>共享栈模式:协程运行时只使用一个小型栈,当协程挂起时,栈帧被序列化到堆,释放线程资源。

这种设计极大减少了内存压力,也让GC可以直接这些栈帧对象。可以说,JVM通过“共享单车”模式,解决了资源浪费的问题。

<>4.[懒加载]:按需枚举,减少无用扫描

协程的挂起栈帧,并不是在GC开始时就全部加载,而是<>等到需要时才动态枚举。这样做就可以降低GC开销,减少不必要的扫描。

这种“<>按需处理”的思路,和Go语言的协程GC优化设计类似,但Ja的实现更加智能化。


<>为什么说JVM的优化是技术的艺术?

JVM在协程与GC的博弈中达成了“动态平衡”,还是有三板斧的:

    <>栈帧对象化:协程栈帧挂起后直接放到堆中,让GC像普通对象一样协程栈帧。<>调度器协作:协程调度器帮助GC跟踪协程的挂起状态。<>批次处理:分批扫描协程,避免性能过载。

这不仅化解了GC的复杂性,还让协程可以以轻量、高效的方式大规模运行。

一句话:<>JVM的协程GC优化是“让复杂的事情变简单”的设计。Ja的VirtualThread也不只是一个“新玩具”,更是未来高性能并发编程的关键一步。

觉得有帮助的话,记得点赞、收、关注~我是旷野,探索无尽技术!

扫描二维码推送至手机访问。

版权声明:本文由卡卷网发布,如需转载请注明出处。

本文链接:https://www.kajuan.net/ttnews/2025/01/8498.html

分享给朋友:

相关文章

感觉手机配置都差不多,为什么有的手机能卖2k-3k,而有的手机却能卖到6k-8k?

感觉手机配置都差不多,为什么有的手机能卖2k-3k,而有的手机却能卖到6k-8k?

与所有的商品一样,手机的价格,也是由它的成本所决定的。虽然看起来3000元的手机和6000的手机配置差不多,甚至处理器都可能是同一个,但在很多大家容易忽略的地方,决定了两者价格的不同:例如手机的外观,塑料的机身,与素皮机身和玻璃机身就完全不...

我觉得华为Mate60Pro明明配置不高,为什么还是有那么多人买呢?

我也好奇啊,所以闲聊时,我问了我们公司的副总,我说Mate60pro配置这么拉胯你怎么还买啊?他一脸疑惑的看着我,配置?什么配置?我这手机信号挺好的啊?我们总经理用的是去年华为出的折叠手机,花了一万多,我也想问问他同样的问题,但奈何一直没有...

为什么说不懂电脑的不要碰AMD?

作为一个资深垃圾佬,说缺点前,先说优点吧AMD CPU(后续简称AU)的优点:处理器对比Intel,三级缓存更大,最明显的感知就是,网游帧数更高(5900X,7900X之类高端型号都是双CCX共享大缓存,反而不如次一点的CPU帧数更高);相...

如何进行 Elasticsearch 调优实践?

如何进行 Elasticsearch 调优实践?

面试官心理分析这个问题是肯定要问的,说白了,就是看你有没有实际干过 es,因为啥?其实 es 性能并没有你想象中那么好的。很多时候数据量大了,特别是有几亿条数据的时候,可能你会懵逼的发现,跑个搜索怎么一下 5~10s ,坑爹了。第一次搜索的...

想学习Linux下的ELF文件有什么好书推荐吗?

想学习Linux下的ELF文件有什么好书推荐吗?

大家好,这里是物联网心球。 今天我们来聊聊ELF文件,了解一下Linux如何创建进程以及ELF文件如何转变成Linux进程?1.什么是ELF文件? ELF(Executable and Linkable Format)文...

什么样的网站能快速捕获你的心?

什么样的网站能快速捕获你的心?

大家好,我是程序员鱼皮。大家如果平时使用网站或产品时出现了问题,一般都会去寻找 “联系客服” 的位置,从而获得人工的帮助。我们团队的面试刷题产品 - 面试鸭最近就遇到了这样一个难题:明明我们网站右下角就有联系客服按钮、而且我们每道面试题目下...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。