jvm学习篇 《一》

来源:互联网 发布:python语言下载 编辑:程序博客网 时间:2024/05/11 21:12

jvm的基本结构

   类加载区:在JVM启动时或者在类运行时将需要的class加载到JVM中。

   执行引擎:负责执行class文件中的字节码指令

   内存区(也叫运行时数据区):是在jvm运行时操作所分配的内存区。运行时内存主要分为5个部分,如下:

                   方法区:用于存储类结构信息的地方,包括常量池、静态变量、构造方法。虽然jvm规范把方法区规定为堆的一个逻辑部分,但它却有个别名non-heap(非堆),不要混淆。方法区还有一个运行时常量池(存放的为类中的固定的常量信息、方法和Field的引用信息等,其空间从方法区域中分配。JVM在加载类时会为每个class分配一个独立的常量池,但是运行时常量池中的字符串常量池是全局共享的)。

                   程序计数器:用于保存当前线程执行的内存地址,jvm是多线程执行的(线程轮流切换),所以为了保证线程切换回来后,还能恢复到原先状态,就需要一个独立的计数器,记录之前中断的地方。程序计数器也是线程私有的。

                   java堆:存储java实例或对象的地方,GC的主要区域。方法区和堆是被所有线程共享的

                   java栈:java栈总是和线程关联在一起,每当创建一个线程时,jvm就为这个线程创建一个对应的java栈(存放的是当前线程中局部基本类型变量,部分返回结果,栈帧。非基本类型的对象在java栈中只存放一个指向堆上的地址),在这个java栈中又会包含多个栈帧,每运行一个方法就创建一个栈帧,用于存储局部变量表,操作栈,方法返回值等。每一个方法从调用直至执行完成的过程,就对应一个栈帧在java栈中入栈到出栈的过程。java栈是线程私有的。

                  本地方法栈:与java栈作用类似,只不过是为jvm使用到的native方法服务的,用于存储每个native方法调用的状态。

参考:http://blog.csdn.net/moneyshi/article/details/53033577
            

    

0 0
原创粉丝点击