Java并发编程
创造线程
ThreadPool
ThreadLocal
乐观与悲观锁
公平与非公平锁
可重入锁与非可重入锁:以ReentrantLock为例
共享锁和排他锁:以ReentrantReadWriterLock读写锁为例
自旋锁和阻塞锁
可中断锁
锁优化
基本类型原子类
AtomicInteger
AtomicLong
AtomicBoolean
数组类型原子类
AtomicIntegerArray
AtomicLongArray
AtomicReferenceArray
引用类型原子类
AtomicReference
AtomicStampedReference
AtomicMarkableReference
升级类型原子类
AtomicIntegerFieldUpdater
AtomicLongFieldUpdater
AtomicReferenceFieldUpdater
Adder累加器
LongAdder
DoubleAdder
Accumulator累加器
LongAccumulator
DoubleAccumulator
原理
应用场景
Java中如何利用CAS实现原子操作
缺点
final的作用与用法
不可变性
栈封闭
ConcurrentHashMap
CopyOnWriteArrayList
并发队列
阻塞队列
非阻塞队列
各个线程之间相互协调
CountDownLatch(一等多,多等一)
Semaphore(控制并发总量)
Condition
CyclicBarrier
state
控制线程抢锁和配合的FIFO队列
期望协作工具类去实现的获取/释放等重要方法
Future接口
主要方法
FutureTask
注意点