JVM内存结构(2)

简介: JVM内存结构

JVM内存结构(1)https://developer.aliyun.com/article/1530765

4. 堆

4.1 定义

Heap 堆

  • 通过new 关键字,创建的对象都会使用堆内存

特点

  • 线程共享,需要考虑线程安全问题
  • 有垃圾回收机制

4.2 堆内存溢出

java.lang.OutofMemoryError :java heap space 堆内存溢出

这就是对象一直不断被使用导致的,他不断自增

Xmx 可以控制堆空间的大小

所以排查堆内存溢出的问题,可以把堆内存设置小一点去测试(不然在内存大的机器中一开始不会暴露出问题)

4.3 堆内存诊断

  1. jps工具
  • 查看当前系统中有哪些java进程

  1. jmap工具
  • 查看堆内存占用情况 jmap - heap 进程id
  1. jconsole工具
  • 图形界面的,多功能的监测工具,可以进行连续监测

案例

  • 垃圾回收后,内存占用仍很高

可视化工具jvisualvm

其中对Dump

5. 方法区

5.1 定义

是所有虚拟机线程共享的区域,它存储了

lt stores per-class structures such as the run-time constant pool, field andmethod data, and the code for methods and constructors, including the specialmethods (S2.9) used in class and instance initialization and interface initialization.

他逻辑上是我们堆的组成部分

但是具体实现上,不同jvm厂商实现不同

5.2 组成

  • 永久代用的堆内存 之前的版本
  • 元空间用的本地内存

5.3 方法区内存溢出

public class main1 extends ClassLoader {//可以用来加载类的二进制字节码
    public static void main(String[] args) {
        int j = 0;
        try {
            main1 test = new main1();
            for (int i = 0; i < 10000; i++,j++) {
                //ClassWriter 作用是生产类的二进制字节码
                ClassWriter cw = new ClassWriter(0);
                //版本号,public,类名,包名,父类,接口
                cw.visit(Opcodes.V1_8, Opcodes.ACC_PUBLIC, "Class" + i, null, "java/lang/Object", null);
                //返回 byte[]
                byte[] code = cw.toByteArray();
                //执行类的加载
                test.defineClass("Class" + i, code, 0, code.length);
            }
        } finally {
            System.out.println(j);
        }
    }
}

这里设置元空间内存

出现了元空间内存溢出

Exception in thread "main" java.lang.OutOfMemoryError: Metaspace
  at java.lang.ClassLoader.defineClass1(Native Method)
  at java.lang.ClassLoader.defineClass(ClassLoader.java:763)
  at java.lang.ClassLoader.defineClass(ClassLoader.java:642)
  at com.itcast.itheima.xpp.main1.main(main1.java:26)
4865
Process finished with exit code 1

老版本是永久代溢出

总结

  • 1.8以前会导致永久代内存溢出java.lang.OutOfMemoryError: PermGen space
  • 1.8以后会导致元空间内存溢出java.lang.OutOfMemoryError: Metaspace

场景

  • spring
  • mybatis

他们会在运行期间动态的生成类的字节码完成类的加载

5.4 运行时常量池

反编译字节码文件

javap -v class文件

类的基本信息

  • 类文件
  • 基本时间
  • 签名
  • 版本
  • 访问修饰符

类的常量池

默认构造方法

方法(包含虚拟机的指令)

获取一个静态变量(System.out)

idc:加载一个参数

invoke:虚方法调用

根据#2查常量池里的表

然后#2引用了一个成员变量

又接着引用了#29#30

类型是 java/io ,变量是out

所以常量池就是

  • 常量池就是一张表,虚拟机指令根据这张表找到要执行的类名,方法名,参数类型,字面量等信息
  • 运行时常量池,常量池是*.class文件中的,当该类被加载,它的常量池信息就会放入运行时常量池,并把里面的符号地址变为真实地址

JVM内存结构(3)https://developer.aliyun.com/article/1530771

相关文章
|
1天前
|
存储 安全 Java
深入理解Java内存模型(JMM)与虚拟机的内存结构(JVM)
深入理解Java内存模型(JMM)与虚拟机的内存结构(JVM)
5 0
|
1天前
|
存储 算法 安全
JVM-内存划分-垃圾回收器-回收算法-双亲委派-三色标记
JVM-内存划分-垃圾回收器-回收算法-双亲委派-三色标记
|
2天前
|
存储 缓存 算法
JVM对象创建与内存分配机制
该类对应的java.lang.Class 对象没有在任何地方被引用,无法在任何地方通过反射访问该类的方法。
7 0
|
2天前
|
存储 Java 对象存储
jvm内存模型剖析
当线程cpu时间片执行完后,线程进入休眠状态,当再次唤醒时,通过程序计数器确定指令执行到哪一行,然后继续往下执行。
12 1
|
2天前
|
存储 安全 Java
JVM之内存结构
Java内存结构包括程序计数器、虚拟机栈、本地方法栈、堆和直接内存。程序计数器记录执行地址,线程私有,无溢出。虚拟机栈处理方法调用,局部变量在线程栈中,过深或过大可能导致StackOverflowError。本地方法栈服务于native方法。堆存储对象,线程共享,有垃圾回收。方法区存储类信息,1.8前的永久代,1.8后的元空间,溢出可调整相应参数。运行时常量池包含字符串池,1.6在永久代,1.8在堆,intern方法管理。直接内存用于NIO,提高读写性能,手动回收。
|
3天前
|
存储 Java C++
Java虚拟机(JVM)管理内存划分为多个区域:程序计数器记录线程执行位置;虚拟机栈存储线程私有数据
Java虚拟机(JVM)管理内存划分为多个区域:程序计数器记录线程执行位置;虚拟机栈存储线程私有数据,如局部变量和操作数;本地方法栈支持native方法;堆存放所有线程的对象实例,由垃圾回收管理;方法区(在Java 8后变为元空间)存储类信息和常量;运行时常量池是方法区一部分,保存符号引用和常量;直接内存非JVM规范定义,手动管理,通过Buffer类使用。Java 8后,永久代被元空间取代,G1成为默认GC。
11 2
|
3天前
|
存储 Java C++
Java虚拟机(JVM)在执行Java程序时,会将其管理的内存划分为几个不同的区域
【6月更文挑战第24天】Java JVM管理内存分7区:程序计数器记录线程执行位置;虚拟机栈处理方法调用,每个线程有独立栈;本地方法栈服务native方法;Java堆存储所有对象实例,垃圾回收管理;方法区(在Java 8后变为元空间)存储类信息;运行时常量池存储常量;直接内存不属于JVM规范,通过`java.nio`手动管理,不受GC直接影响。
16 5
|
7天前
|
存储 Java 编译器
【搞定Jvm面试】 面试官:谈谈 JVM 类文件结构的认识
【搞定Jvm面试】 面试官:谈谈 JVM 类文件结构的认识
|
7天前
|
监控 算法 Java
Java虚拟机(JVM)使用多种垃圾回收算法来管理内存,以确保程序运行时不会因为内存不足而崩溃。
【6月更文挑战第20天】Java JVM运用多种GC算法,如标记-清除、复制、标记-压缩、分代收集、增量收集、并行收集和并发标记,以自动化内存管理,防止因内存耗尽导致的程序崩溃。这些算法各有优劣,适应不同的性能和资源需求。垃圾回收旨在避免手动内存管理,简化编程。当遇到内存泄漏,可以借助VisualVM、JConsole或MAT等工具监测内存、生成堆转储,分析引用链并定位泄漏源,从而解决问题。
17 4
|
9天前
|
算法 Java
Java垃圾回收(Garbage Collection,GC)是Java虚拟机(JVM)的一种自动内存管理机制,用于在运行时自动回收不再使用的对象所占的内存空间
【6月更文挑战第18天】Java的GC自动回收内存,包括标记清除(产生碎片)、复制(效率低)、标记整理(兼顾连续性与效率)和分代收集(区分新生代和老年代,用不同算法优化)等策略。现代JVM通常采用分代收集,以平衡性能和内存利用率。
36 3