JVM

HotSpot是JVM的核心组件,JDK每次版本更新在于JDK以及JVM的运行效率(对class文件的解析以及编译)。

在1.3之前版本,核心不是HotSpot,当运行class时,通过classLoader加载到虚拟机中,JVM需要将class文件编译成本地代码(CPU能够直接处理),每次加载class都需要转换,转换频率越多性能消耗越大。在1.3版本之后(jdk1.5真正引入),引入HotSpot(热点探测),对class文件做标记,当达到一定阈值时,触发JIT(即时编译),对频繁使用的class文件直接编译成本地代码进行缓存,以便于下次直接运行(不必再次编译)。

JVM有两个版本,client以及server,其为一个JVM,只是采用两套不同机制初始化,client对桌面级应用进行内存分配进行优化(内存分配空间相比server端要小,因为其交互相比于B/S效率要低),其为JVM默认启动的。在JDK的安装文件中,即jdk内jre中lib下,有i386的目录内有jvm.cfg,内部有-client 以及 -server,谁在上边就以什么形式启动。

1)类加载子系统与方法区:类加载子系统负责从文件系统或者网络中加载class,加载的类信息存放于称为方法区的内存空间。除类信息外,方法区可能存放运行时常量池信息,包括字符串字面量和数字常量(这部分常量信息是class文件中常量池部分的映射)

2)java堆:在JVM启动时建立,主要内存工作区域,几乎所有对象实例存放在java堆中,堆空间由所有线程共享。

3)直接内存:java的NIO库允许java使用直接内存,直接内存是在java堆外的,直接向系统申请的内存空间,通常访问直接内存的速度由于java堆。出于性能考虑,读写频繁的场合可能会考虑使用直接内存,由于在java堆外,因此其大小不会直接受限于Xmx指定的最大堆大小,但是系统内存有限,java堆和直接内存的综合受限于操作系统所能给出的最大内存。

4)垃圾回收系统:可以对java堆,方法区,以及直接内存进行回收。其中java堆是回收重点,和c/c++不同,java中所有的对象空间释放都是隐式的,对于不再使用的垃圾对象,垃圾回收系统会在后台查找、标识并释放垃圾对象。

5)java栈:每个java虚拟机线程都有私有的java栈,一个线程的java栈在线程创建的时候创建,java栈中保存着帧信息,java栈中保存着局部变量、方法参数,同时和java方法的调用、返回密切相关。

6)本地方法栈:本地方法栈与java栈类似,不同在于java栈用于方法的调用,而本地方法栈用于本地方法的调用,作为对java虚拟机的重要扩展,java虚拟机允许java直接调用本地方法(通常使用c编写)。

7)PC寄存器:PC寄存器是每一个线程的私有空间,JVM为每一个线程创建PC寄存器,在任意时刻,线程总是在执行一个方法,这个正在被执行的方法称为当前方法。如果当前方法不是本地方法,PC寄存器就会指向当前正在被执行的指令,如果当前方法是本地方法,那么PC寄存器的值就是undefined。

8)执行引擎:负责执行java的字节码,现代虚拟机为了提高执行效率,会使用即使编译技术将方法编译成机器码后再执行。

JVM根据对象存活周期不同,将堆内存划分为几块,一般分为新生代,老年代和永久代(对HotSpot而言),此为JVM内存分代策略。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值