JVM总结 结构梳理

jvm 总体梳理

jvm体系总体分四大块:我对每一块进行了精简总结,具体请点下面文字进行转跳

1.类的加载机制         

2.jvm内存结构

3.GC算法 垃圾回收          

4.GC分析 命令调优

总体框架图:

* 类加载器,在 JVM 启动时或者类运行时将需要的 class 加载到 JVM 中

* 执行引擎,执行引擎的任务是负责执行 class 文件中包含的字节码指令,相当于实际机器上的 CPU

* 内存区,将内存划分成若干个区以模拟实际机器上的存储、记录和调度功能模块,如实际机器上的各种功能的寄存器或者 PC 指针的记录器等

* 本地方法调用,调用 C 或 C++ 实现的本地方法的代码返回结果

___________________________________________________________________________

JVM运行时的数据区

                                 

1.线程计数器,是一块较小的内存空间,用来指定当前线程执行字节码的行数,每个线程计数器都是私有的,因为每个线程都需要记录执行的行数;这里解释一下为什么每个线程都需要一个线程计数器,JVM的多线程是通过线程轮流切换分配执行时间来实现的,在任何时刻,每个处理器都只会执行一个线程中的指令,当线程进行切换的时,为了线程能恢复当正确的位置,所以每个线程必须有个独立的线程计数器,这样才能保证线程之间不互相影响。

.Java栈(虚拟栈),这个也是一个线程私有的,生命周期与线程是同步的每个方法在执行的同时,都会创建一个栈帧,用于存储局部变量表,操作数栈,动态                                    链接,方法出入口等信息,每个方法的调用到执行完成的过程就是一个栈帧入栈到出栈的过程;

    局部变量表:局部变量表存储方法相关的局部变量,包括基本数据,对象引用和返回地址等。在局部变量表中,只有long和double类型会占用2个局部变量空间(Slot,对于32位机器,一个Slot就是32个bit),其它都是1个Slot。需要注意的是,局部变量表是在编译时就已经确定好的,方法运行所需要分配的空间在栈帧中是完全确定的,在方法的生命周期内都不会改变。

 3.本地方法栈,与虚拟机栈执行的基本相同,唯一的区别就是虚拟机栈是执行Java方法的,本地方法栈是执行native方法的;

 4.,堆区是Java虚拟机所管理的内存中最大的一块,Java堆是被所有线程共享的内存区域,主要存储对象的实例。

       当堆中没有内存完成实例分配,并且堆无法扩展的时候,将会抛出OutOfMemoryError异常;当前虚拟机都是可以扩展的;

 5.方法区,这个也是线程共享的内存区域,存储被虚拟机加载的类信息、常量、静态变量、即时编译的代码数据等;

    方法区在物理上也是不需要连续的,可以选择固定大小或者扩展的大小,还可以选择不实现垃圾收集,方法区的垃圾回收是比较少的,这就是方法区为什么被称为永久区的原因,但是方法区也是可以执行回收的,该区域主要是针对常量池和类型的卸载;在方法区也规定当方法区无法满足内存分布的时候,将会抛出OutOfMemoryError异常;运行时常量是方法区的一部分,常量池主要用于存放编译生成的各种字面量和符合引用,由于常量池属于方法区的一部分,所以当常量池没有内存空间的时候就抛出OutOfMemoryError异常;

 6.直接内存,不是虚拟机运行时的一部分,可以直接访问堆外的内存;所以当内存空间无法动态扩展的时候就会出现OutOfMemoryError异常;

JDK?

    jdk在这个体系中充当一个生产加工中心,产生全部的数据输出,是全部指令和战略的运行中心.本身它提供了Java的完整方案,能够开发眼下Java能支持的全部应用和系统程序.这里说一个问题,大家会问,那为什么还有j2me,j2ee这些东西,这两个东西目的非常easy,分别用来简化各自领域内的开发和构建过程.jdk除了JVM之外,另一些核心的API,集成API,用户工具,开发技术,开发工具和API等组成

    好了,废话说了那么多,来点于主题相关的东西吧.JVM在整个jdk中处于最底层,负责于操作系统的交互,用来屏蔽操作系统环境,提供一个完整的Java执行环境,因此也就是虚拟计算机. 操作系统装入JVM是通过jdk中Java.exe来完毕,通过以下4步来完毕JVM环境.

猜你喜欢

转载自blog.csdn.net/qq_29373285/article/details/85039367
今日推荐