本篇博客是转过来的。 但是略有改动感谢 http://my.oschina.net/noahxiao/blog/101558摘要从使用场景的角度出发来介绍对ReentrantLock的使用,相对来说容易理解一些。场景1:如果发现该操作已经在执行中则不再执行(有状态执行) a、用在定时任务时,如果任务...
分类:
编程语言 时间:
2015-06-15 18:24:35
阅读次数:
199
细粒度锁: java中的几种锁:synchronized,ReentrantLock,ReentrantReadWriteLock已基本可以满足编程需求,但其粒度都太大,同一时刻只有一个线程能进入同步块,这对于某些高并发的场景并不适用。比如银行客户a向b转账,c向d转账,假如这两个线程并发,代码其....
分类:
编程语言 时间:
2015-06-11 18:22:10
阅读次数:
463
锁作为并发共享数据,保证一致性的工具,在JAVA平台有多种实现(如 synchronized 和 ReentrantLock等等 ) 。这些已经写好提供的锁为我们开发提供了便利,但是锁的具体性质以及类型却很少被提及。本系列文章将分析JAVA下常见的锁名称以及特性,为大家答疑解惑。四、可重入锁:本文里...
分类:
编程语言 时间:
2015-06-10 18:45:10
阅读次数:
141
package sgs;import java.util.concurrent.locks.ReentrantLock;import sgs.GameThread;public class playerThread implements Runnable{ public playerThread(i...
分类:
编程语言 时间:
2015-06-10 18:39:02
阅读次数:
107
转会:http://www.blogjava.net/xylz/archive/2010/07/05/325274.html前面的章节主要谈谈原子操作,至于与原子操作一些相关的问题或者说陷阱就放到最后的总结篇来总体说明。从这一章開始花少量的篇幅谈谈锁机制。上一个章节中谈到了锁机制,而且针对于原子操作...
分类:
编程语言 时间:
2015-06-10 12:09:49
阅读次数:
154
CopyOnWriteArrayList原理 首先每次写操作,都将数组copy一份,并赋值给arrays 读操作读不加锁 写操作加锁 ReentrantLock 因为每次写都要copy数组,这是一项繁重的操作,因此 CopyOnWriteArrayList适合读多写少的情况。 add方法的源码如下:...
分类:
编程语言 时间:
2015-06-05 12:15:09
阅读次数:
241
分布式锁在分布式应用当中是要经常用到的,主要是解决分布式资源访问冲突的问题。 一开始考虑采用ReentrantLock来实现,但是实际上去实现的时候,是有问题的,ReentrantLock的lock和unlock要求必须是在同一线程进行,而分布式应用中,lock和unlock是两次不相关的请求,因此肯定不是同一线程,因此导致无法使用ReentrantLock。 接下来就考虑采用自己做个状态来进行...
分类:
其他好文 时间:
2015-06-05 00:48:01
阅读次数:
126
---恢复内容开始---public class ReentrantLockextends Objectimplements Lock, Serializable 一个可重入的互斥锁... 使用公平锁的被多线程访问的程序可能比那些使用默认设置的程序显出更低的吞吐性能(也就是速度慢,通常慢很多),.....
分类:
编程语言 时间:
2015-06-03 19:30:46
阅读次数:
111
代码示例: Lock lock = new ReentrantLock();
lock.lock();
try { // update object state
} finally { lock.unlock();
}
相比synchronized的优势
1.具有更好的并发性能,激烈争用情况下更佳的...
分类:
其他好文 时间:
2015-06-01 18:42:28
阅读次数:
169
1. 什么是可重入锁(ReentrantLock)? 答: java.util.concurrent.lock 中的 Lock 框架是锁定的一个抽象,它允许把锁定的实现作为 Java 类,而不是作为语言的特性来实现。这就为 Lock 的多种实现留下了空间,各种实现可能有不同的调度算法、性能特性或.....
分类:
编程语言 时间:
2015-06-01 18:34:05
阅读次数:
188