Java高并发程序-Chapter3 JDK并发包(第十七讲)同步控制之ReentrantLock 的实现
2018-03-28 08:17
579 查看
ReentrantLock 的实现
1. CAS
2. 等待队列
3. park()
说明: ReentrantLock 默认使用NonfairSync 的 lock 方法
说明: NonfairSync 的 lock 方法 使用CAS ,如果某一个Thread (命名 ThreadA) 成功将stateOffset 从0变成1 (利用CPU指令集在一个事务中完成),这个线程 ThreadA 获取到当前lock(独占锁),进行线程Run执行。其他 Threads 由于 stateOffset =1 无法操作成功,必须调用 acquire 尝试获取lock。 大家奇怪stateOffset =1 ,如何还原成0呢, 当时在 unlock 方法中。
再次try acquire 获取lock, 如果不成功, 调用acquireQueued(addWaiter(Node.EXCLUSIVE), arg)
addWaiter(Node.EXCLUSIVE) 添加到Queue 队列中,这个队列通过CAS,是一个简单的无堵塞队列。
将Thread Node 添加到Queue tailer出。
for (;;) {
Node t = tail; // 妙笔, 必须先prev临时保存上一个tailer,然后通过CAS 完成tailer 赋值成new node,成功后可以[b]new node前插入prev
if (t == null) { // Must initialize
if (compareAndSetHead(new Node()))
tail = head;
} else {
node.prev = t;
if (compareAndSetTail(t, node)) { //通过CAS 确认新的Node设置到tailer,如果失败,重复操作。
t.next = node;
return t;
}
}
}
[/b]
通过LockSupport park 当前 Thread
unlock 方法
从 队列tailer 开始,获取 Thread Node, 必须时有效的, 从Node 取出 Thread 进行 unpark操作。
1. CAS
2. 等待队列
3. park()
说明: ReentrantLock 默认使用NonfairSync 的 lock 方法
说明: NonfairSync 的 lock 方法 使用CAS ,如果某一个Thread (命名 ThreadA) 成功将stateOffset 从0变成1 (利用CPU指令集在一个事务中完成),这个线程 ThreadA 获取到当前lock(独占锁),进行线程Run执行。其他 Threads 由于 stateOffset =1 无法操作成功,必须调用 acquire 尝试获取lock。 大家奇怪stateOffset =1 ,如何还原成0呢, 当时在 unlock 方法中。
再次try acquire 获取lock, 如果不成功, 调用acquireQueued(addWaiter(Node.EXCLUSIVE), arg)
addWaiter(Node.EXCLUSIVE) 添加到Queue 队列中,这个队列通过CAS,是一个简单的无堵塞队列。
将Thread Node 添加到Queue tailer出。
for (;;) {
Node t = tail; // 妙笔, 必须先prev临时保存上一个tailer,然后通过CAS 完成tailer 赋值成new node,成功后可以[b]new node前插入prev
if (t == null) { // Must initialize
if (compareAndSetHead(new Node()))
tail = head;
} else {
node.prev = t;
if (compareAndSetTail(t, node)) { //通过CAS 确认新的Node设置到tailer,如果失败,重复操作。
t.next = node;
return t;
}
}
}
[/b]
通过LockSupport park 当前 Thread
unlock 方法
从 队列tailer 开始,获取 Thread Node, 必须时有效的, 从Node 取出 Thread 进行 unpark操作。
相关文章推荐
- Java高并发程序-Chapter3 JDK并发包(第九讲)同步控制之 ReentrantLock 重用锁
- Java高并发程序-Chapter3 JDK并发包(第十二讲)同步控制之 ReadWriteLock
- Java高并发程序-Chapter3 JDK并发包(第十四讲)同步控制之自己动手实现 CoutDownLatch
- Java高并发程序-Chapter3 JDK并发包(第十六讲)同步控制之LockSupport
- Java高并发程序-Chapter3 JDK并发包(第十一讲)同步控制之 Semaphore
- Java高并发程序-Chapter3 JDK并发包(第十五讲)同步控制之CyclicBarrier 循环栅栏
- Java高并发程序-Chapter3 JDK并发包(第十讲)同步控制之 Condition
- Java高并发程序-Chapter3 JDK并发包(第十八讲)同步控制之自定义SafeQueue
- Java高并发程序-Chapter3 JDK并发包(第十三讲)同步控制之 CoutDownLatch
- java高并发程序设计总结三:JDK并发包之ReentrantLock重入锁
- java并发锁ReentrantLock源码分析一 可重入支持中断锁的实现原理
- Java高并发程序-Chapter3 JDK并发包(第二十讲)Fork/Join
- Java并发——重入锁ReentrantLock的实现原理及源码解析
- Java并发基础框架AbstractQueuedSynchronizer初探(ReentrantLock的实现分析)
- Java高并发程序设计笔记5之JDK同步控制
- Java 并发及同步相关 Synchronized ReentrantLock
- 【Java并发编程】15、ReentrantLock实现原理深入探究
- java并发控制:ReentrantLock Condition使用详解
- 【Java并发编程实战】– 使用读写锁实现同步数据访问 lock_2
- java并发编程之:ReentrantLock实现原理与深入研究