菜鸟笔记
提升您的技术认知

threadlocal原理及使用场景-ag真人游戏

​ threadlocal意为线程本地变量,用于解决多线程并发时访问共享变量的问题。

​ 所谓的共享变量指的是在堆中的实例、静态属性和数组;对于共享数据的访问受java的内存模型(jmm)的控制,其模型如下:

【参考:《java并发编程的艺术》p22】

每个线程都会有属于自己的本地内存,在堆(也就是上图的主内存)中的变量在被线程使用的时候会被复制一个副本线程的本地内存中,当线程修改了共享变量之后就会通过jmm管理控制写会到主内存中。

​ 很明显,在多线程的场景下,当有多个线程对共享变量进行修改的时候,就会出现线程安全问题,即数据不一致问题。常用的解决方法是对访问共享变量的代码加锁(synchronized或者lock)。但是这种方式对性能的耗费比较大。在jdk1.2中引入了threadlocal类,来修饰共享变量,使每个线程都单独拥有一份共享变量,这样就可以做到线程之间对于共享变量的隔离问题。

​ 当然锁和threadlocal使用场景还是有区别的,具体区别如下:

synchronized(锁) threadlocal
原理 同步机制采用了时间换空间的方式,只提供一份变量,让不同线程排队访问(临界区排队) 采用空间换时间的方式,为每一个线程都提供一份变量的副本,从而实现同时访问而互不相干扰
侧重点 多个线程之间访问资源的同步 多线程中让每个线程之间的数据相互隔离

一、threadlocal的使用及原理

1.1 使用

  1. 一般都会将threadlocal声明成一个静态字段,同时初始化如下:
static threadlocal
网站地图