JVM内存模型的那些事

  阅读相关资料,自己先画了一个jvm内存模型草图

  类装在子系统不过多解释,上一篇类加载机制说的就是这个。

  字节码执行引擎(执行编译好后class文件指令码的程序),为C语音实现,不可见,不展开讲,下面主要来看内存模型中的5块。

  

  芜湖起飞~

  先从栈开始讲:

    栈后面加了个括号,线程,栈就是线程在执行方法的时候存放的一些方法内部的局部变量。

    当一个线程执行方法,会在栈里面开辟这个线程的栈空间。栈中有n个线程方法空间,我们看下面的程序

public class Stack {


    public int add() {
        int a =1;
        int b = 2;
        int c = (a+b) * 2;
        return c;
    }



    public static void main(String[] args) {
        Stack stack = new Stack();

        stack.add();
    }

}

  我们执行main函数,开启主线程,这个时候,栈会开辟一个main线程空间,如下图:

  这里来解释一个重要的概念:先进后出。

    我们看程序,先执行main方法:这时候,main方法栈帧入栈(栈帧:每个线程开启时对应的方法内存区域)

   然后main方法调用add方法,这个时候add方法入栈:

  然后add方法执行完了,add方法出栈:

  最后是main方法执行完成,main方法出栈:

  上面这个过程很好的解释了栈的先进后出的概念。

  上图中每一个方法在对应线程的栈空间中都有与之相对应的栈帧,那么栈帧中又有啥呢?看下图:

   

  

猜你喜欢

转载自www.cnblogs.com/ghsy/p/13387005.html