软弱引用
软引用:
只有在内存不足的时候JVM才会回收该对象
SoftReference m = new SoftReference<>(new byte(1024 * 1024 * 10));
m是强引用,里面的字节数组是弱引用
装在软引用里面的才是软引用
弱引用:
无论内存是否充足,都会回收被弱引用关联的对象
WeakReference m = new WeakReference<>(new M());
spring里面声明式事务内部是怎么实现的?ThreadLocal
Spring事务Transitional使用ThreadLocal来保证多个sql语句使用的是同一个数据库连接。大家可以通过源码去证实一下这个问题!
弱引用的使用—>ThreadLocalMap: Entry
static class Entry extends WeakReference<ThreadLocal<?>>{
…
}
Entry-> WeakReferenceKey:value
为何这么设计?
ThreadLocal tl = new ThreadLocal();
tl 引用 ThreadLocal对象,而ThreadLocalMap的key引用的也是ThreadLocal,tl=null可以解开tl的引用,但ThreadLocalMap对ThreadLocal的引用解不开,这样会导致内存泄露。
t1.remove()的必要性?
1、当使用线程池的时候,如果没有remove,那这个线程放回线程池,然后被其他地方获取到这个线程后,另一个线程可能会得到之前设置的threadLocal的值,造成混淆
2、ThreadLocalMap里面的key是弱引用,被回收掉了,但value值并没有被回收掉,可能还会出现内存泄露,所以调用remove().
3、解开tl与ThreadLocal的引用关系,使得ThreadLocal能够被回收