最近网上出现一个美团面试题:“一个线程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性能优化的面试整体,由于文章的长度限制,没有将所有的答案都给大家分享出来,除了性能优化,小编还整理了有微服务,开源框架,并发编程,分布式专题,有需要的朋友可以点击此处获取。