面试刷题24:介绍一枚 JAVA妹妹?

2020-03-31 16:06:18来源:博客园 阅读 ()

新老客户大回馈,云服务器低至5折

面试刷题24:介绍一枚 JAVA妹妹?

java提供的自动垃圾收集机制大大提高了程序员的开发效率。
但是自动垃圾收集不是万能的,明确jvm的内存结构,工作机制是设计高扩展应用的基础。
也是诊断jvm运行时问题的必备技能。

我是李福春,我在准备面试,今天的题目是:

jvm的内存结构是怎样的?哪些区域容易发生OOM?

答:分3部分回答,具体如上图所示:

1,线程私有的:分为虚拟机栈,本地方法栈,程序计数器;

2,线程共享的:分为堆,方法区(元数据,常量池)

3,jvm之外的:分为直接内存和 code cache ;

然后为每个部分分别展开说明一下。

虚拟机栈: 每个线程的一次方法执行都对应一个虚拟机栈的栈帧,包含方法入参,操作数,动态链接,方法正常结束或者异常退出的定义

本地方法栈:线程调用本地方法对应一个本地方法栈,跟虚拟机栈在同一块区域;

程序计数器:记录线程正在执行的jvm指令地址

堆:java的对象生成区域,所有的线程共享,是垃圾收集的重点照顾区域,可以进一步分为新声代,老年代,xms设置的是堆大小;

方法区:放了java的类对象定义,以及常量池;

发生OOM的区域如图所示,除了程序计数器部分,其它的部分都可能直接或者间接的引起OOM(OutOfMemoryError);

分别说明如下:

1,堆, 如内存泄露,堆大小设置不合理,运行期间对象的回收不及时,都可能引起堆的OOM;

2,栈:栈的无限递归调用直接导致StackOverFlowError,jvm会重新扩展栈空间,引起OOM;

3,方法区:老版本常量池的回收非常不积极;比如字符串缓存堆积;

4,给的元数据空间不足以及直接内存不足也是可能引起OOM;

小结

本节画了java的jvm的内存结构图,分别分析了每一块的用途;

然后针对每一块可能产生OOM的原因做了分类。

image.png

原创不易,转载请注明出处。


原文链接:https://www.cnblogs.com/snidget/p/12605967.html
如有疑问请与原作者联系

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:一次线上升级大规模报错后,我又重新学习了序列化!

下一篇:详解:如何设计出健壮的秒杀系统?