面经------锁

目录

volatile

ThreadLocal

Atomic原子类

AQS

wait与sleep 的区别

核心线程与非核心线程有区别吗?


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()。

你可能感兴趣的:(java基础,学习)