本文目录:
写在开头
在 Java 的多线程模块中,ThreadLocal
是经常被提问到的一个知识点。
1.什么是 ThreadLocal
早在 JDK 1.2 中就已经为我们提供了ThreadLocal
类。ThreadLocal 类的出现,为解决多线程程序的并发问题提供了一种新的思路。使用这个工具类,我们可以很简洁的来编写多线程程序。
当多线程同步访问
共享数据时,为了保证数据的原子操作,我们可以使用 1.synchronized加锁方式
或者2.使用AtomicInteger等原子类
的方式来解决多线程之间的共享数据问题。很多人会将 ThreadLocal 和共享数据混为一谈,但这两个却是完全不同的概念。
重点区别:共享数据
是多个线程对同一数据的访问,是时间换空间
的思想;而ThreadLocal
使用到的是线程封闭
,是空间换时间
的思想;(线程封闭:即数据都被封闭在各自的线程之中,各自线程操作各自的值,并不会涉及到多线程的同步问题,这种通过将数据封闭在各自线程中而避免使用