首页 > 代码库 > JVM的结构与内存分配

JVM的结构与内存分配

参考:http://blog.csdn.net/tonytfjing/article/details/44278233

 

   JVM的结构

    技术分享

     一般认为,JVM分为四大部分:  

    1.类加载器(ClassLoader):在JVM启动时或者在类运行时将需要的class加载到JVM中。

    2.字节码执行引擎:负责执行class文件中包含的字节码指令;

    3.本地方法接口:主要是调用C或C++实现的本地方法及返回结果。

    4.内存区(也叫运行时数据区):是在JVM运行的时候操作所分配的内存区。运行时内存区主要可以划分为5个区域:   

  • 方法区(Method Area):用于存储类结构信息的地方,包括常量池、静态变量、构造函数等。虽然JVM规范把方法区描述为堆的一个逻辑部分, 但它却有个别名non-heap(非堆),所以大家不要搞混淆了。
  • java堆(Heap):存储java实例或者对象的地方,这块是GC的主要区域。方法区和堆是被所有java线程共享的。
  • java栈(Stack):java栈总是和线程关联在一起,每当创建一个线程时,JVM就会为这个线程创建一个对应的java栈。在这个java栈中又会包含多个栈帧,每运行一个方法就创建一个栈帧,用于存储局部变量表、操作栈、方法返回值等。每一个方法从调用直至执行完成的过程,就对应一个栈帧在java栈中入栈到出栈的过程。
  • 程序计数器(PC Register):用于保存当前线程执行的内存地址。由于JVM程序是多线程执行的(线程轮流切换),所以为了保证线程切换回来后,还能恢复到原先状态,就需要一个独立的计数器,记录之前中断的地方,程序计数器是线程私有的。
  • 本地方法栈(Native Method Stack):和java栈的作用差不多,只不过是为JVM使用到的native方法服务的

   java栈、程序计数器、本地方法栈都是线程私有的,线程生就生,线程灭就灭,栈中的栈帧随着方法的结束也会撤销,内存自然就跟着回收了。所以这几个区域的内存分配与回收是自动的。

    java堆和方法区则不一样,我们只有在程序运行期间才知道会创建哪些对象,所以这部分内存的分配和回收都是动态的,垃圾回收也是针对这一部分。

JVM的结构与内存分配