JVM随笔

JVM随笔:

  • JVM发展:Classic VM —>HotSpot VM+JRokit VM —>整合HotSpot VM(主流jvm)

  • JVM源码结构

  • JVM内存区域:

    JVM内存区域共分为5大块。分别为堆内存(Heap),方法区(Method Area),本地方法栈(Native Method Stack),虚拟机栈(JVMStacks)和程序计数器;
    堆内存:主要储存 java 方法在运行过程中 new 出来的对象->String str = new String();则new String()则存储于堆内存中,GC垃圾收集器(分代回收算法)主要工作于此区域,所有线程共享些区域,易出现OutOfMemoryError异常。

方法区:主要储存经过JVM加载之后的类信息class,常量 final,静态变量 static和编译后的代码等数据,垃圾回收器也将作用于此区域进行废弃数据回收。

虚拟机栈:主要储存局部变量(byte,boolean,char,short,float,int,double,long)以及对象的引用String str = new String()–>str,操作数栈,动态链接,方法出口等信息。每个java方法执行时会创建一个栈桢,栈桢的入栈到出栈 对应着一个java方法调用开始直至结束的过程。为 JVM执行java方法服务。操作数栈是JVM的一个工作区->加法运算->JVM使用指令将两个数从局部变量中提出来,然后压入到操作数栈中,再执行加法操作,最后将结果压入到操作数栈中,再将操作栈中的结果值储存到局部变量的索引中,以索引引出结果展示。

本地方法栈:主要储存程序中使用到的 Native方法(非java语言编写)—>java调用非java代码的接口:native public void Native1( int x ) ;

程序计数器:较小的内存区间,主要储存当前线程执行到某个位置,通过计数器的值来选择下一条需要执行的字节码指令,程序的分支,集合的循环,方法之间的跳转或者异常处理等都需要根据程序计数器来指定,每个线程独立拥有一个程序计数器。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章