用于存放已被加载的类信息、常量、静态变量。 面:谈谈元空间(MetaSpace)和永久代(PermGen)的区别?

均是方法区(JVM的一种规范)的实现 JDK8后元空间替代了永久代 元空间使用本地内存,而永久代使用的是jvm内存,这解决了空间不足的问题。

包含多个栈帧一个栈帧包括局部变量表操作栈动态链接返回地址等方法的调用即对于栈帧从虚拟机stack中入栈到出栈的过程

面:为什么要使用双亲委派机制去加载类? 答:避免多份同样字节码的加载,浪费内存。

隐式加载:new 显示加载:loadClass、forName等 类的装载过程如下图:

一般将-Xms与-Xmx设置为同样的数值,避免堆扩容时发生的内存抖动,影响程序的稳定性。

静态存储:编译时确定每个数据目标在运行时的存储空间需求 栈式存储:数据区需求在编译时未知,在运行时模块入口前确定 堆式存储:编译时或运行时模块入口都无法确定需求,需要动态分配

-Xss:规定了每个线程虚拟机栈(堆栈)的大小 -Xms:堆的初始值 -Xmx:堆能达到的最大值

线程私有:程序计数器、虚拟机栈、本地方法栈 线程共享:MetaSpace、Java堆

当前线程所执行的字节码行号指示器(逻辑) 通过改变计数器的值来选取下一条需要执行的字节码指令 和线程是一对一的关系即“线程私有” 对Java方法计数,如果是Native方法则计数器的值为Undefined 不会发生内存泄漏

JDK6:当调用intern方法时,如果字符串常量池先前已创建出该字符串对象,则返回池中的该字符串的引用。否则将此字符串对象添 加到字符串常量池中,并且返回该字符串对象的引用。 JDK6:当调用intern方法时,如果字符串常量池先前已创建出该字符串对象,则返回池中该字符串的引用。否则,如果该字符串对象 已经存在与Java堆中,则将堆中对此对象的引用添加到字符串常量池中,并且返回该引用;如果堆中不存在该对象,则在字符串常量池 中创建该字符串并返回其引用。

联系:引用对象、数组时,栈里定义变量来保存堆中目标的首地址 管理方式:栈自动释放,堆需要GC 空间大小:一般栈比堆小 碎片相关:栈产生的内存碎片远小于堆 分配方式:栈支持静态和动态分配,而堆仅支持动态分配 效率:栈的效率比堆高(栈只有入栈与出栈)

字符串常量池(JDK1.7开始移动到Java堆中)存在与永久代中,容易出现性能问题和内存溢出 类的方法的信息大小难以确定,给永久代的大小的指定带来了困难 永久代会为GC带来不必要的复杂性 方便HotSpot与其他JVM如Jrockit的集成(因为永久代是HotSpot独有的)

由于篇幅限制,小编在此截出几张知识讲解的图解,有需要的程序猿(媛)可以点赞后获取哦

Java方法执行的内存模型 包含多个栈帧(一个栈帧包括局部变量表、操作栈、动态链接、返回地址等,方法的调用即对于栈帧从虚拟机Stack中入栈到出栈的过 程) 当线程请求的栈深度超过最大值,会抛出 StackOverflowError 异常; 栈进行动态扩展时如果无法申请到足够内存,会抛出 OutOfMemoryError 异常。

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注