目录
volatile
volatile关键字无法保证原子性 ,更准确地说是volatile关键字
只能保证单操作的原子性, 比如x=1
,但是无法保证复合操作的原子性,比如x++
所谓原子性:即一个或者多个操作作为一个整体,要么全部执行,要么都不执行,并且操作在执行过程中不会被线程调度机制打断;而且这种操作一旦开始,就一直运行到结束,中间不会有任何上下文切换(context switch)
ThreadLocal
ThreadLocal
提供了一种简单而有效的方式,使得每个线程都能够在其范围内存储和访问数据,从而实现线程级别的数据隔离和线程安全。它在多线程编程中被广泛运用,常见的应用场景包括线程池、Web应用的会话管理、数据库连接管理等。然而,在使用 ThreadLocal
时要注意合理使用,避免产生内存泄漏和过度使用 ThreadLocal
导致的资源浪费等问题。
Atomic原子类
Atomic是jdk提供的一系列包的总称,这个大家族包括原子整数(AtomicInteger,AtomicLong,AtomicBoolean),原子引用(AtomicReference,AtomicStampedReference,AtomicMarkableReference),原子数组(AtomicIntegerArray,AtomicLongArray,AtomicReferenceArray),更新器(AtomicIntegerFieldUpdater,AtomicLongFieldUpdater,AtomicReferenceFieldUpdater)。
AQS
AQS提供一系列结构,作为一个完整的模板,自定义的同步器只需要实现资源的获取和释放就可以,而不需要考虑底层的队列修改、状态改变等逻辑。
wait与sleep 的区别
功能都是当前线程暂停。
wait放开手去睡,放开手里的锁。调用它的前提是当前线程占有锁。
sleep握紧手去睡,醒了手里还有锁,不会释放锁,不需要占用锁。
核心线程与非核心线程有区别吗?
没有。被销毁的线程和创建的先后无关。即便是第一个被创建的核心线程,仍然有可能被销毁
验证:看源码,每个work在runWork()的时候去getTask(),在getTask内部,并没有针对性的区分当前work是否是核心线程或者类似的标记。只要判断works数量超出core,就会调用poll(),否则take()。