ThreadLocal的底层原理

(1)ThreadLocal是Java中所提供的线程本地存储机制,可以利用该机制将数据缓存在某个线程内部,该线程可以再任意时刻、任意方法中获取缓存的数据。
(2)ThreadLocal底层是通过ThreadLocalMap来实现的,每个Thread对象中(注意不是ThreadLocal对象)都存在一个ThreadLocalMap,Map的key是ThreadLocal对象,Map的value是需要缓存的值。
(3)如果在线程池中使用ThreadLocal会造成内存泄露,因为当ThreadLocal对象使用完之后,应该吧要设置的key,value,也就是Entry对象回收,但是线程池中的线程不会被回收,而线程对象是通过强引用指向ThreadLocalMap,ThreadLocalMap通过强引用指向Entry对象,线程不被回收,那么Entry对象也不会被回收,从而出现内存泄露,解决办法是在使用了ThreadLocal对象之后,手动调用ThreadLocal的remove方法,手动清楚对象。
(4)ThreadLocal经典的应用场景就是连接管理(一个线程持有一个连接,该连接对象可以再不同方法之间传递,线程之间不共享同一个连接)。
在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/weixin_49131718/article/details/131795407
今日推荐