ReentrantLock与synchronized的差别
总的来说,lock更加灵活。
主要同样点:Lock能完毕synchronized所实现的全部功能
不同:
1.ReentrantLock功能性方面更全面,比方时间锁等候,可中断锁等候,锁投票等,因此更有扩展性。
在多个条件变量和高度竞争锁的地方,用ReentrantLock更合适,ReentrantLock还提供了Condition,对线程的等待和唤醒等操作更加灵活。一个ReentrantLock能够有多个Condition实例。所以更有扩展性。
2.ReentrantLock必须在finally中释放锁,否则后果非常严重,编码角度来说使用synchronized更加简单。不easy遗漏或者出错。
3.ReentrantLock 的性能比synchronized会好点。
4.ReentrantLock提供了可轮询的锁请求。他能够尝试的去取得锁,假设取得成功则继续处理,取得不成功,能够等下次执行的时候处理,所以不easy产生死锁。而synchronized则一旦进入锁请求要么成功,要么一直堵塞。所以更easy产生死锁。
转载:
http://houlinyan.iteye.com/blog/1112535
1、ReentrantLock 拥有Synchronized同样的并发性和内存语义,此外还多了 锁投票,定时锁等候和中断锁等候
线程A和B都要获取对象O的锁定,如果A获取了对象O锁。B将等待A释放对O的锁定,
假设使用 synchronized ,假设A不释放,B将一直等下去,不能被中断
假设 使用ReentrantLock,假设A不释放。能够使B在等待了足够长的时间以后。中断等待,而干别的事情
ReentrantLock获取锁定与三种方式:
a) lock(), 假设获取了锁马上返回,假设别的线程持有锁,当前线程则一直处于休眠状态,直到获取锁
b) tryLock(), 假设获取了锁马上返回true,假设别的线程正持有锁,马上返回false;
c)tryLock(long timeout,TimeUnit unit), 假设获取了锁定马上返回true,假设别的线程正持有锁,会等待參数给定的时间,在等待的过程中。假设获取了锁定,就返回true,假设等待超时。返回false。
d) lockInterruptibly:假设获取了锁定马上返回,假设没有获取锁定,当前线程处于休眠状态。直到或者锁定。或者当前线程被别的线程中断
2、synchronized是在JVM层面上实现的,不但能够通过一些监控工具监控synchronized的锁定,并且在代码运行时出现异常,JVM会自己主动释放锁定。可是使用Lock则不行,lock是通过代码实现的。要保证锁定一定会被释放,就必须将unLock()放到finally{}中
3、在资源竞争不是非常激烈的情况下,Synchronized的性能要优于ReetrantLock,可是在资源竞争非常激烈的情况下,Synchronized的性能会下降几十倍。可是ReetrantLock的性能能维持常态。
參考文章:
- http://houlinyan.iteye.com/blog/1112535
- http://zhangjunhd.blog.51cto.com/113473/70300/
- http://hi.baidu.com/ecspell/item/d9fa870a22eafa354bc4a3ae
- http://my.oschina.net/u/1042978/blog/127207
ReentrantLock与synchronized的差别的更多相关文章
- Java中的ReentrantLock和synchronized两种锁定机制的对比
问题:多个访问线程将需要写入到文件中的数据先保存到一个队列里面,然后由专门的 写出线程负责从队列中取出数据并写入到文件中. http://blog.csdn.net/top_code/article/ ...
- ReentrantLock和synchronized两种锁定机制
ReentrantLock和synchronized两种锁定机制 >>应用synchronized同步锁 把代码块声明为 synchronized,使得该代码具有 原子性(atomicit ...
- java多线程之:Java中的ReentrantLock和synchronized两种锁定机制的对比 (转载)
原文:http://www.ibm.com/developerworks/cn/java/j-jtp10264/index.html 多线程和并发性并不是什么新内容,但是 Java 语言设计中的创新之 ...
- Java中的ReentrantLock和synchronized两种锁机制的对比
原文:http://www.ibm.com/developerworks/cn/java/j-jtp10264/index.html 多线程和并发性并不是什么新内容,但是 Java 语言设计中的创新之 ...
- Java中的ReentrantLock和synchronized两种锁定
原文:http://www.ibm.com/developerworks/cn/java/j-jtp10264/index.html 多线程和并发性并不是什么新内容,但是 Java 语言设计中的创新之 ...
- Java中的ReentrantLock和synchronized两种锁定机制
原文:http://www.ibm.com/developerworks/cn/java/j-jtp10264/index.html 多线程和并发性并不是什么新内容,但是 Java 语言设计中的创新之 ...
- ReentrantLock与synchronized
1.ReentrantLock 拥有Synchronized相同的并发性和内存语义,此外还多了 锁投票,定时锁等候和中断锁等候 线程A和B都要获取对象O的锁定,假设A获取了对象O锁,B将等待A释放对O ...
- Java ReentrantLock和synchronized两种锁定机制的对比
多线程和并发性并不是什么新内容,但是 Java 语言设计中的创新之一就是,它是第一个直接把跨平台线程模型和正规的内存模型集成到语言中的主流语言.核心类库包含一个 Thread 类,可以用它来构建.启动 ...
- ReentrantLock和synchronized区别和联系?
相同:ReentrantLock提供了synchronized类似的功能和内存语义,都是可重入锁. 不同: 1.ReentrantLock功能性方面更全面,比如时间锁等候,可中断锁等候,锁投票等,因此 ...
随机推荐
- android小知识
string 与 []byte 互转: public String BytesToString(byte[] data) { return new String(data); } public byt ...
- CFUUIDRef和CFStringRef-生成唯一标识符
- (NSString *)createCUID:(NSString *)prefix{ NSString * result; CFUUIDRef uuid; CFStringRef uuidS ...
- Immutable Object模式
多线程共享变量的情况下,为了保证数据一致性,往往需要对这些变量的访问进行加锁.而锁本身又会带来一些问题和开销.Immutable Object模式使得我们可以在不使用锁的情况下,既保证共享变量访问的线 ...
- C/C++ 开源库及示例代码
C/C++ 开源库及示例代码 Table of Contents 说明 1 综合性的库 2 数据结构 & 算法 2.1 容器 2.1.1 标准容器 2.1.2 Lockfree 的容器 2.1 ...
- VC6.0 list sort出错
在STL中,排序是个很重要的话题. 1.algorithm 里的sort()只接收RandomAccessIterator用于像vector,dequeue的排序 2.像set,map,这种关联式容器 ...
- 在前台运行Service
一个前台的 service是被用户强烈关注的从而不会在内存低时被系统杀死.前台 service必须在状态栏上提供一个通知,这个通知被放在"正在进行"区域中,这表示这个通知不能被解除,除非服务停止了或者 ...
- WITH AS 优化逻辑读
SQL> select * from fxqd_list_20131115_new where (acct_no, oper_no, seqno, trans_amt) not in (sele ...
- poj2482
(题外话:这题这是ACMer的福利啊……)我非常不擅长做矩形类的数据结构一般来说,二维的问题我们要转化为一维来考虑感觉一般的手法是对一维排序,并且线性扫描这一维,然后用各种数据结构维护另一维上的最优值 ...
- HDU-2509 Be the Winner
http://acm.hdu.edu.cn/showproblem.php?pid=2509 Be the Winner Time Limit: 2000/1000 MS (Java/Others) ...
- 《JavaScript核心概念》基础部分重点摘录
注:<JavaScript核心概念>适合深入了解JavaScript,比我买的<JavaScript框架设计>语言和内容丰富多了(可能是我水平尚浅吧). 1. 作用域 var ...