解决内存泄露的问题

一、 浅谈四种引用类型
1.强引用

 User user = new User();

特点:只要强引用存在,垃圾回收器将永远不会回收被引用的对象,哪怕内存不足时,JVM也会直接抛出OutOfMemoryError,不会去回收。如果想中断强引用与对象之间的联系,可以显示的将强引用赋值为null,这样一来,JVM就可以适时的回收对象了
2.弱引用

WeakReference<User> wr = new WeakReference<>(new User());
	   wr.get()
	   System.gc();

特点:如果你是弱引用 ,无论内存是否够用,当垃圾回收器工作的时候 会直接干掉
3.软引用

SoftReference<byte[]> sr = new SoftReference<>(new byte[1024*1024]);
 SoftReference SoftReference = new SoftReference(new GyyqQueryInfo());

特点:如果是软引用,在内存足够的时候,gc 工作的时候不会管,只有内存满的时候才会清理软引用,多应用于缓存比如网页缓存,图片缓存等。

4.虚引用

ReferenceQueue a = new ReferenceQueue<>();
        PhantomReference<SysWebEnterprise> PhantomReference = new PhantomReference<>(new SysWebEnterprise(),a);

虚引用是最弱的一种引用关系,如果一个对象仅持有虚引用,那么它就和没有任何引用一样,它随时可能会被回收,多和队列一起使用

面试总结:

1.java中 的引用类型有哪几种
答:强引用,弱引用 软引用 虚引用 
2. 每种引用的特点以及引用场景 
答: 上面的介绍
3.ThreadLocal你了解么?
答:线程本地化
只有自己的线程可以看,并且拿出来 其他的线程拿不到 
4.ThreadLocal应用在哪些地方?
答:
1.我们调服务的时候 传参 a 调b的方法 b调c 的方法 这样如果用ThreadLocal 就可以避免传参 
2. Spring 中的事务底层使用ThreadLocal,用来隔离数据
   ThreadLocal 的k v 
	    ThreadLocal<SysWebEnterprise> t1 = new ThreadLocal<>();
        SysWebEnterprise sysWebEnterprise1= new SysWebEnterprise();
        t1.set(sysWebEnterprise1);
	t1=null; 如果k 是强引用 就收不掉了 
	
	只要只有弱引用 就直接干掉解决泄露问题 
	
	泄露越来越多 就会产生内存溢出 
	
	
    k 是谁
    k 是他自己 this  t1 

	k 是弱引用  t1 是强引用 
	由于 k 是弱引用 直接干掉了那么 v 干不掉了 
	必须要有这个 
	t1.remove();
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Owen_Number_One

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值