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功能性方面更全面,比如时间锁等候,可中断锁等候,锁投票等,因此 ...
 
随机推荐
- C#中标准Dispose模式的实现
			
http://www.cnblogs.com/luminji/archive/2011/03/29/1997812.html 需要明确一下C#程序(或者说.NET)中的资源.简单的说来,C#中的每一个 ...
 - python【第十一篇】消息队列RabbitMQ、缓存数据库Redis
			
大纲 1.RabbitMQ 2.Redis 1.RabbitMQ消息队列 1.1 RabbitMQ简介 AMQP,即Advanced Message Queuing Protocol,高级消息队列协议 ...
 - linux源码“.config”文件分析
			
一..config文件概述 .config文件是linux内核配置文件,当执行#make uImage编译生成内核时,顶层的Makefile会读取.config文件的内容,根据这个配置文件来编译所定制 ...
 - EFBaseDal新增删除方法
			
public T Delete(int id ) { var entity = db.Set<T>().Find(id); T t ...
 - Python处理XML
			
在Python(以及其他编程语言)内有两种常见的方法处理XML:SAX(Simple API for XML)和DOM(Document Object Model,文档对象模型).SAX语法分析器读取 ...
 - PYTHON调用JENKINS的API来进行CI
			
我查到的相关API有两套,我主要用的是python-jenkins. https://pypi.python.org/pypi/python-jenkins/ 按语法调用即可... import je ...
 - 用F340 GPIO做I2C
			
在和Qinheng开发小尺寸点灯治具中,F340和FPGA采用I2C通信,其中F340作为I2C的主机,I2C端口用自己的GPIO编写,总结遇到的问题及注意事项: 1. F340端口及上拉电阻设置: ...
 - 如何对一个不断更新的HashMap进行排序
			
如何对一个不断更新的HashMap进行排序? 解答:等到HashMap更新稳定后,用ArrayList包装进行排序.或者自己写一个可以类似HashMap的有序Map,每次更新的时候都进行排序,构建自己 ...
 - ECHO.js  纯javascript轻量级延迟加载
			
演示 <!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="utf ...
 - BZOJ2134: 单选错位
			
题目:http://www.lydsy.com/JudgeOnline/problem.php?id=2134 题解:因为每个答案之间是互不影响的,所以我们可以挨个计算. 假设当前在做 i 题目,如果 ...