博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ReentrantLock和Synchronized
阅读量:5246 次
发布时间:2019-06-14

本文共 841 字,大约阅读时间需要 2 分钟。

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是在层面上实现的,不但可以通过一些监控工具监控synchronized的锁定,而且在代码执行时出现异常,会自动释放锁定,但是使用Lock则不行,lock是通过代码实现的,要保证锁定一定会被释放,就必须将unLock()放到finally{}中 3、在资源竞争不是很激烈的情况下,Synchronized的性能要优于ReetrantLock,但是在资源竞争很激烈的情况下,Synchronized的性能会下降几十倍,但是ReetrantLock的性能能

转载于:https://www.cnblogs.com/lnas01/p/4963244.html

你可能感兴趣的文章
软件测试2019:第五次作业
查看>>
JS异步加载的三种方案
查看>>
设计模式---简单工厂和工厂模式
查看>>
我的第一次算法分析笔记
查看>>
ZOJ 3870 Team Formation(二进制找规律)
查看>>
Redis内存模型
查看>>
cisa备考体会
查看>>
timus1004 最小环()Floyd 算法
查看>>
数据结构05之高级排序
查看>>
python 字典实现类似c的switch case
查看>>
面试问题总结
查看>>
ubuntu qq
查看>>
redis 常用命令
查看>>
【转载】C#常用数据库Sqlserver通过SQL语句查询数据库以及表的大小
查看>>
_kbhit() for linux
查看>>
Mayor's posters POJ - 2528
查看>>
决策树--信息增益,信息增益比,Geni指数的理解
查看>>
常用sql备份
查看>>
Solr源码在MyEclipse下的搭建
查看>>
Oracle用户管理的不完全恢复2:基于取消的恢复
查看>>