前言:我们都知道当eden满了会触发minor gc,那这时候被回收的都是一些什么对象呢?
1.强引用
强引用:简单的理解为我们自己new出来的一个对象。
Student student = new Student();
student.setName("luo_li");
//当对象为null后gc就会回收这个没有用的对象
student = null;
System.gc();
System.out.println(student);
System.in.read();
null
finalize执行
结论:这里我们能看到当我们new出来的对象被赋值为null后,当gc时就会被回收掉,对应的finalize方法也会执行。否在这个对象是不会被回收的程序宁可出现OOM错误。
2.软引用
软引用SoftReference:SoftReference的特点是它的一个实例保存一个其他对象的软引用。
如果一个对象是有软引用的,那么当内存不足时,垃圾回收机制是会回收它的,当内存足够时,则不会回收。
SoftReference softReference = new SoftReference(new byte[1024 * 1024 * 10]);
System.out.println(softReference.get());
System.gc();
System.out.println(softReference.get());
ThreadUtil.sleep(5, TimeUnit.MILLISECONDS);
//当再次去堆内存中划分内存时,由于内存不足,会回收掉软应用
byte[] bytes = new byte[1024 * 1024 * 11];
System.out.println(softReference.get());
[B@6fb554cc
[B@6fb554cc
null
结论:当程序中再出去堆内存中划分内存时,由于内存不足,会回收掉早些前的软引用。
3.弱引用
弱引用WeakReference:当程序进行GC时,无论内存是否充足只要有弱引用的对象都会被回收掉。
WeakReference weakReference = new WeakReference(new Student());
System.out.println(weakReference.get());
System.gc();
System.out.println(weakReference.get());
com.es.demo.demo2.Student@614c5515
null
finalize执行
结论:只要程序进行GC,弱引用都会被垃圾回收器回收掉。
4.虚引用
虚引用PhantomReference:如果一个对象是存在虚引用,则在任何时候都可能被垃圾回收器回收。一般是和引用队列一起使用。
5.弱引用实现缓存
public SoftReference<BannerManager> softReference = null;
public BannerManager getByIdBannerManager() {
if (softReference== null) {
BannerManager bannerManager = bannerManagerMapper.selectByPrimaryKey(20);
softReference = new SoftReference<>(bannerManager);
System.out.println("查询数据库");
return bannerManager;
}
System.out.println("查询缓存");
return softReference.get();
}
上面的代码只是告诉大家实现缓存的代码步骤,实现方式肯定不应该这么做。