运行时数据区
其他
Java中的四种引用类型
- 强引用
在 Java 中最常见的就是强引用,把一个对象赋给一个引用变量,这个引用变量就是一个强引用
。当一个对象被强引用变量引用时,它处于可达状态,它是不可能被垃圾回收机制回收
的,即使该对象以后永远都不会被用到 JVM 也不会回收。因此强引用是造成 Java 内存泄漏的主要原因之一
- 软引用
软引用需要用 SoftReference 类来实现,对于只有软引用的对象来说,当系统内存足够时它不会被回收,当系统内存空间不足时它会被回收
。软引用通常用在对内存敏感的程序中。 - 弱引用
弱引用需要用 WeakReference 类来实现,它比软引用的生存期更短,对于只有弱引用的对象来说,只要垃圾回收机制一运行,不管 JVM 的内存空间是否足够,总会回收该对象占用的内存
。 - 虚引用
虚引用需要 PhantomReference 类来实现,它不能单独使用,必须和引用队列联合使用。虚引用的主要作用是跟踪对象被垃圾回收的状态 => 如何理解?
新生代什么时候会进入老年代
- 1.长期存活的对象将进入老年代
虚拟机对每个对象定义了一个对象年龄(Age)计数器。当年龄增加到一定的临界值时,就会晋升到老年代中,该临界值由参数:-XX:MaxTenuringThreshold来设置。 - 2.大对象直接进入老年代
-XX:PretenureSizeThreshold即对象的大小大于此值, 就会绕过新生代, 直接在老年代分配, 此参数只对Serial及ParNew两款收集器有效。 - 3.空间分配担保
当MinorGC时,如果存活对象过多,无法完全放入Survivor区,就会向老年代借用内存存放对象
,以完成MinorGC - 4.动态对象年龄判定
如果Survivor区中相同年龄所有对象的大小总和大于Survivor区空间一半
,年龄大于或者等于该年龄的对象在MinorGC时将复制到老年代
双亲委派模型
- 双亲委派模型的优点
1.避免类的重复加载:父加载器完成了加载,子加载器就不会去加载 =>向下返回的过程中
就能确定是否已经加载,父类已经加载或者父类可以加载就没有子类什么事情了…;
2.保护Java核心API:假设通过网络传递一个名为java.lang.Integer的类,通过双亲委托模式传递到启动类加载器,而启动类加载器在核心Java API发现这个名字的类,发现该类已被加载/可加载,并不会重新加载网络传递的过来的java.lang.Integer,而直接返回已加载过的Integer.class,这样便可以防止核心API库被随意篡改。