美文网首页JAVA
面试官:JDK8内存分布

面试官:JDK8内存分布

作者: 秦时的明月夜 | 来源:发表于2019-09-28 16:56 被阅读0次

内存组成部分

根据 JVM 规范,JVM内存共分为虚拟机栈、堆、方法区、程序计数器、本地方法栈五个部分。

image.png

虚拟机栈

每个线程都有一私有栈,随着线程的创建而创建。栈里面会存放着“栈帧”,每个方法创建一个栈帧。
栈帧的组成部分:
一、局部变量:存放基本的数据类型(bytecharintdouble,float,boolean,long,short)和对象地址引用(一个指针指向对象或者一条指令)。局部变量区被定义一个从0开始的数字数组,byteCharshortboolean转换成intlong ,double, 2个字节。其中64 位长度的longdouble 类型的数据会占用2个局部变量空间(Slot),其余的数据类型只占用1个。局部变量通过数组的下标访问。
备注:局部变量表中的Slot是可重用的,方法体中定义的变量,其作用域并不一定会覆盖整个方法,如果当前字节码PC计算器的值已经超出了某个变量的作用域,那么这个变量对应的Slot就可以交给其它变量使用。
二、操作数栈:数组,先进后出,pushpop操作。
三、帧数据区:
1、解析常量池的数据
2、方法执行完后处理方法返回,恢复调用方现场
3、方法执行过程中抛出异常时异常的处理,当出现异常时虚拟机查找相应的异常表看是否有对应的catch语句,如果没有就抛出异常终止这个方法调用。
如果栈内存不够将会抛出StackOverflowError错误。catch 捕获的是 Throwable类。
调整栈内存大小参数-Xss:每个线程的stack大小(栈)

虚拟机堆

堆内存是 JVM所有线程共享的部分,在虚拟机启动的时候就已经创建。所有的对象和数组都在堆上进行分配。这部分空间可通过 GC 进行回收。
当申请不到空间时会抛出 OutOfMemoryErrorcatch捕获的是 Throwable
调整堆参数大小参数:
XmxJava Heap的最大值、默认为物理内存的1/4
XmsJava Heap的初始值,server端最好Xms与Xmx一样
XmnJava Heapyoung区的大小
XX:MetaspaceSize 元数据初始大小
XX:MaxMetaspaceSize 元数据内存最大值
JDK1.8中,取消了PermGen,取而代之的是Metaspace
元数据空间并不在虚拟机中,而是使用本地内存。

方法区

方法区也是所有线程共享。主要用于存储类的信息、常量池、方法数据、方法代码等。方法区逻辑上属于堆的一部分,但是为了与堆进行区分,通常又叫“非堆”。

本地方法区

这部分主要与虚拟机用到的 Native方法相关,一般情况下, Java 应用程序员并不需要关心这部分的内容。

程序计数器

JVM支持多个线程同时运行,每个线程都有自己的程序计数器。倘若当前执行的是 JVM 的方法,则该寄存器中保存当前执行指令的地址;倘若执行的是Native方法,则程序计数器中为空。

举例

image.png

相关文章

  • 面试官:JDK8内存分布

    内存组成部分 根据 JVM 规范,JVM内存共分为虚拟机栈、堆、方法区、程序计数器、本地方法栈五个部分。 虚拟机栈...

  • 面试官:怎么做JDK8的内存调优?

    面试官:怎么做JDK8的内存调优? 看着面试官真诚的眼神,心中暗想看起来年纪轻轻却提出如此直击灵魂的问题。擦了擦额...

  • Java内存管理

    Java内存管理-JVM内存模型以及JDK7和JDK8内存模型对比总结

  • 触摸java常量池

    java常量池是一个经久不衰的话题,也是面试官的最爱,题目花样百出。理论jvm虚拟内存分布: ** 程序计...

  • 4种方法教你如何查看java对象所占内存大小

    计算java对象所占内存大小 1.使用jdk8自带API 使用这种jdk8方式时,Open JDK 不是天然支持的...

  • Z_HPC_内存

    分布式内存 共享式内存

  • Effective Objective-C读后笔记(1)

    1、Objective-C中的内存分布 对象类型内存分布在堆里面,是直接管理内存。 指针类型分布在栈里面系统帮我们...

  • 1.内存区域及内存溢出异常

    内存区域组成 包括:{堆、方法区}所有线程共享数据区。在JDK8中,hotspot宣布移除PermGen内存区域,...

  • hashMap

    参考资料:吊打面试官面试必备:HashMap源码解析(JDK8)Java 8系列之重新认识HashMapHashM...

  • JVM基本知识-内存结构

    JVM的内存结构 jdk8 jvm说明根据oracle官方文档的描述,可以总结JVM运行时内存的划分 Java虚拟...

网友评论

    本文标题:面试官:JDK8内存分布

    本文链接:https://www.haomeiwen.com/subject/atnvuctx.html