JVM 堆内存溢出后,其他线程是否可继续工作?

当一个线程发生堆内存溢出(OOM)时,其他线程通常仍能继续运行。堆溢出会导致该线程占用的内存资源被释放,不会直接影响其他线程。然而,频繁的垃圾回收(GC)可能会对其他线程的性能产生负面影响。
摘要由CSDN通过智能技术生成

最近网上出现一个美团面试题:“一个线程OOM后,其他线程还能运行吗?”

我看网上出现了很多不靠谱的答案。这道题其实很有难度,涉及的知识点有jvm内存分配、作用域、gc等,不是简单的是与否的问题。

由于题目中给出的OOM,java中OOM又分很多类型。比如:
堆溢出(“java.lang.OutOfMemoryError: Java heap space”)、
永久带溢出(“java.lang.OutOfMemoryError:Permgen space”)、
不能创建线程(“java.lang.OutOfMemoryError:Unable to create new native thread”)等很多种情况。

本文主要是分析堆溢出对应用带来的影响。先说一下答案,答案是还能运行。
代码如下:
在这里插入图片描述
结果展示:
在这里插入图片描述
JVM启动参数设置:
在这里插入图片描述
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值