最近网上出现一个美团面试题:“一个线程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启动参数设置:
上图是JVM堆空间的变化。我们仔细观察一下在14:42:05~14:42:25之间曲线变化,你会发现使用堆的数量,突然间急剧下滑!这代表这一点,当一个线程抛出OOM异常后,它所占据的内存资源会全部被释放掉,从而不会影响其他线程的运行!
讲到这里大家应该懂了,此题的答案为一个线程溢出后,进程里的其他线程还能照常运行。注意了,这个例子我只演示了堆溢出的情况。如果是栈溢出,结论也是一样的,大家可自行通过代码测试。
2019年jvm性能优化相关的大厂面试真题:
Java类加载过程java内存分配描述一下jvm加载class文件的原理机制GC是什么?为什么要有GC?简述java垃圾回收机制如何判断一个对象是否存活?(或者GC对象的判定方法)垃圾回收的优点和原理。并考虑2种回收机制。垃圾回收器的基本原理是什么?垃圾回收器可以马上回收内存吗?有什么办法主动通知虚拟机进行垃圾回收?java中会存在内存泄漏吗,请简单描述。深拷贝和浅拷贝syatem,gc()和runtime,gc()会做做什么事情?finalize方法什么时候被调用?析构函数(finalizatinon)的目的是什么?如何对象的引用被置为null,垃圾收集器是否会立即释放对象占用的内存?什么是分布式垃圾回收(DGC)?它是如何工作的?串行(serial)收集器和吞吐量(throughout)收集器的区别是什么?在Java中,对象什么时候可以被垃圾回收?简述Java内存分配与回收策率以及minor GC和majorGC。jvm的永久代中会发生垃圾回收吗?Java中垃圾收集的方法有哪些?什么是类加载器,类加载器有哪些?jvm性能优化一直是大厂面试考察的一个重点,上面给大家展示的是一部分jvm性能优化的面试整体,由于文章的长度限制,没有将所有的答案都给大家分享出来,除了性能优化,小编还整理了有微服务,开源框架,并发编程,分布式专题,有需要的朋友可以关注小编+转发文章+私信【面试真题】获取。
本文来自投稿,不代表本人立场,如若转载,请注明出处:http://www.sosokankan.com/article/1854888.html