JVM整体结构及内存模型

发布于:2023-02-02 ⋅ 阅读:(191) ⋅ 点赞:(0)

1、栈(线程)

每个栈有多个栈帧,每个栈帧代表一个方法,里面存局部变量

public class Math {
    public static void main(String[] args) {
        Math math = new Math();
        math.compute();
        System.out.println("gytest");

    }

    public int compute() {
        int a = 1;
        int b = 2;
        int c = (a + b) * 10;
        return c;

    }
}
  • 局部变量表:在每个方法中暂存局部变量的内存。

  • 操作数栈:在方法中局部变量进行计算的内存。

  • 动态链接:在运行math.compute()时,将这个方法符号的直接地址指针,放到动态链接中。

  • 方法出口:当compute()方法执行完,再回到main方法中math.cpmpute()方法处的位置,回到哪个位置放在方法出口中。

  • main栈帧的局部变量表是放的堆中对象的内存地址。

2、方法区/元空间

常量+静态变量+类信息

public static Math math = new Math();

math是放在方法区中,new Math()放在堆中,然后方法区指向堆。意思是方法区中放的是对象的内存地址。

3、本地方法栈

比如new Thread().start()的start()方法是native方法,是c++写的

4、堆

被线程共享的一块内存区域,创建的对象和数组都保存在堆内存中,也是垃圾收集器进行垃圾收集最重要的内存区域

5、程序计数器

当前线程所执行的字节码的行号指示器,每条线程都有一个独立的线程计数器。是虚拟机中唯一一个没有规定任何OutOfMemoryError情况的区域。

内存参数设置

 

关于元空间的jvm参数有两个:-XX:MetaspaceSize=N和-XX:MaxMetaspaceSize=N,对于64位JVM来说,元空间的默认初始大小是21MB,默认的元空间的最大值是无限。

-XX:MaxMetaspaceSize: 设置元空间最大值,默认是--1,即不限制,或者说只受限于本地内存大小。

-XX:MetaspaceSize:指定元空间的初始空间大小,以字节为单位,默认是21MB,达到该值就会触发full gc进行类型卸载,同时收集器会对该值进行调整:如果释放了大量的空间,就适当降低该值;如果释放了很少的空间,那么在不超过元空间最大值的情况下,适当提高该值。

由于调整元空间的大小需要full gc,是非常昂贵的操作,如果应用在启动的时候发生大量的full gc,通常都是由于永久代或元空间发生了大小调整,基于这种情况建议两个值设置成一样的值,并设置得比初始值要大,对于8g物理内存的机器来说,一般将这两个值设置位256M。


网站公告

今日签到

点亮在社区的每一天
去签到