美文网首页
JVM基础(一)

JVM基础(一)

作者: Maxinxx | 来源:发表于2019-03-15 11:20 被阅读0次

引子


第三行有两个单词需要注意,第一个是HotSpot,第二个是Server。

  • HotSpot
    jvm的作用是将cpu看不懂的.class文件变成cpu看的懂的本地代码。java每次在更新版本的时候,都需要对jvm进行调优,如果jvm频繁的对.class文件进行解析,将浪费大量资源。所以,提出了一个比较好的办法,那就是HopSpot(热点追踪),即对于一些解析非常频繁的.class文件,直接保存它解析好的在本地,便不需要浪费资源去频繁解析了。
  • Server
    jvm有两种模式,一种是Server,一种是Client。Server和Client模式可以在bin中进行调换。他们的差别就是在jvm自动分配内存的时候,给Server分配的内存要比Client大一些,Client主要是用于桌面应用编程的,Server用于并发编程,所以需要的内存要大一些。

jvm结构

Java虚拟机的基本结构
  • 类加载子系统与方法区
    类加载子系统负责从文件系统或者网络中加载class信息,加载的类信息存放于一块成为方法区的内存空间。除了类的信息外,方法区中可能还会存放运行时常量池信息,包括字符串字面量和数字常量(这部分常量信息是class文件中常量池部分的内存映射)。
  • java堆
    java堆在虚拟机启动的时候建立,它是java程序最主要的内存工作区域。几乎所有的java对象实例都存放在java堆中。堆空间是所有线程共享的,这是一块与java应用密切相关的内存空间。
  • 直接内存
    java的NIO库允许java程序使用直接内存。直接内存是在java堆外的、直接向系统申请的内存空间。通常访问直接内存的速度会优于java堆。因此出于性能的考虑,读写频繁的场合可能会考虑使用直接内存。由于直接内存在java堆外,因此它的大小不会直接受限于Xmx指定的最大堆大小,但是系统内存是有限的,java堆和直接内存的总和依然受限于操作系统能给出的最大内存。
  • 垃圾回收系统
    垃圾回收系统是java虚拟机的重要组成部分,垃圾回收器可以对方法区、java堆和直接内存进行回收。其中,java堆是垃圾收集器的工作重点。和c/c++不同,java中所有的对象空间释放都是隐式的,也就是说,java中没有类似free()或者delete()这样的函数释放指定的内存区域。对于不再使用的垃圾对象,垃圾回收系统会在后台默默工作,默默查找、标识并释放垃圾对象,完成包括java堆、方法区和直接内存中的全自动化管理。
  • java栈
    每一个Java虚拟机线程都有一个私有的Java栈,一个线程的Java栈在线程创建的时候被创建,Java栈中保存着帧信息,Java栈中保存着局部变量、方法参数,同时和Java方法的调用、返回密切相关。
  • 本地方法栈
    本地方法栈和Java栈非常类似,最大的不同在于Java栈用于方法的调用,而本地方法栈则用于本地方法的调用,作为对Java虚拟机的重要扩展,Java虚拟机允许Java直接调用本地方法(通常使用c编写)
  • PC(Program Counter)
    PC寄存器也是每一个线程私有的空间,Java虚拟机会为每一个Java线程创建PC寄存器。在任意时刻,一个Java线程总是在执行一个方法,这个正在被执行的方法称为当前方法。如果当前方法不是本地方法,PC寄存器就会指向当前正在被执行的指定。如果当前方法是本地方法,那么PC寄存器的值就是undefined
  • 执行引擎
    执行引擎是Java虚拟机的最核心组件之一,它负责执行虚拟机的字节码,现代虚拟机为了提高执行效率,会使用即使编译(just in time)技术将方法编译成机器码后再执行。

相关文章

网友评论

      本文标题:JVM基础(一)

      本文链接:https://www.haomeiwen.com/subject/raucmqtx.html