1 JVM基本结构1)类加载器classLoader:在JVM启动时或者类运行时将需要的.class文件加载到内存中 2)内存区域(运行时数据区): 是在JVM运行的时候操作所分配的内存区 3)执行引擎:负责执行class文件中包含的字节码指令 4)本地方法接口:主要是调用C/C++实现的本地方法及返回结果 2 JVM内存结构1 ) 方法区:用于存储类结构信息的地方,包括常量池、静态变量、构造函数等。 2) Java堆(heap):存储Java实例或者对象的地方。这块是gc的主要区域 3) Java栈(stack):Java栈总是和线程关联的,每当创建一个线程时,JVM就会为这个线程创建一个对应的Java栈。在这个java栈中又会包含多个栈帧,每运行一个方法就创建一个栈帧,用于存储局部变量表、操作栈、方法返回值等。每一个方法从调用直至执行完成的过程,就对应一个栈帧在java栈中入栈到出栈的过程。所以java栈是线程私有的。 4)程序计数器:用于保存当前线程执行的内存地址,由于JVM是多线程执行的,所以为了保证线程切换回来后还能恢复到原先状态,就需要一个独立的计数器,记录之前中断的地方,可见程序计数器也是线程私有的 5)本地方法栈:和Java栈的作用差不多,只不过是为JVM使用到的native方法服务的 3 Java对象引用Java对象的引用可以分为4类:强引用、软引用、弱引用和虚引用。 1)强引用:通常可以认为是通过new出来的对象,即使内存不足,GC进行垃圾收集的时候也不会主动回收。
2)软引用:在内存不足的时候,GC进行垃圾收集的时候会被GC回收
3)弱引用:无论内存是否充足,GC进行垃圾收集的时候都会回收
4)虚引用:和弱引用类似,主要区别在于虚引用必须和引用队列一起使用
引用队列:如果软引用和弱引用被GC回收,JVM就会把这个引用加到引用队列里,如果是虚引用,在回收前就会被加到引用队列里。 4 GC机制垃圾收集器一般完成两件事->检测出垃圾->回收垃圾 1) 对象的年龄相关知识对象的年龄,如果在一次垃圾回收过程中有使用该对象的,则将对象年龄加1,否则减1,当计数为0,则进行回收,如果年龄达到一定数字则进入老生代。总的来说内存分配机制主要体现在对象创建之后是否仍在使用,已经不使用的则回收,继续使用的则对其年龄进行更新,达到一定程度,转移到年老代。 下图所示是堆中内存分配示意图,创建一个对象,首先会在eden区域分配区域,如果内存不够,就会将年龄大的转移到Survivor区,当survivor区域存储不下,则会转移年老代的。对于一些静态变量不需要使用对象,直接调用的,则会被放入永生代。一般来说长期存活的对象最终会被存放到年老代,还有一种特殊情况也会被存放到年老代,就是创建大对象时,比如数据这种需要申请连续空间的,如果空间比较大的,则会直接进入年老代 2) 垃圾检测方法
3) 垃圾回收算法
|
|