JavaSE---显式锁
1、概述
1.1、jdk5之前,用于 调节共享对象访问机制 只有 synchronized、volatile;
jdk5之后,提供了 显示锁:Lock、ReentrantLock...;
显式锁 并不是 内部锁机制 的替代,而是 当内部锁被证明受到局限时,提供可选择的高级特性;
1.2、Lock接口
1.2.1、Lock接口,定义了 一些 抽象的锁操作;
与内部锁机制不同,Lock 提供了 无条件的、可轮询、定时、可中断 的 锁获取操作;
所有的加锁、解锁都是 显式的;
1.2.2、Lock的实现 提供了 与 内部锁 相同的内存可见性;
但 加锁的语义、调度算法、顺序保证、性能特征 与内部锁不同;
1.3、ReentrantLock接口
1.3.1、ReentrantLock 实现了 Lock 接口,提供了 与 synchronized 相同的互斥、内存可见性;
1.3.2、为何要创建与内部锁如此相似的机制?
内部锁 大部分情况下 能很好地工作,但是 有一些功能上的局限(不能中断 那些正在 等待获取锁的线程,且 请求锁失败的情况下,必须无限等待);
1.3.3、注意事项:
a,锁 必须 在finally 块中释放;
b,如果 锁守护的代码 在 try块之外抛出异常,它将 永远不会被释放了;
1.3.4、可轮询、可定时的锁获取
I、可定时、可轮询的锁获取,由 tryLock()实现;
与 无条件的 锁获取 相比,它具有更完善的错误恢复机制;
II、可定时、可轮询的锁获取,可以避免 死锁 的发生(在内部锁中,死锁是致命的,唯一的恢复方法是重启应用程序,构建程序时不允许出错);
III、对于实现那些 具有时间限制 的活动,定时锁同样非常有用;
1.3.5、可中断的锁获取
I、可中断的锁获取 允许 在可取消的活动中使用;
II、当你 正在响应中断的时候,lockInterrupter()能够使你获取锁,且 它是内置于 Lock的,不需要再创建其他种类不可中断的阻塞机制;
1.3.6、非块结构的锁
I、???
2、锁的性能
2.1、内部锁(synchronized) 与 显式锁(Lock) 的性能和可伸缩性 是基于平台的,比如:CPU、处理器数量、高速缓存大小、JVM特性...;
3、锁的公平性
3.1、ReentrantLock 构造函数 提供了 2种公平性的选择:
a,非公平锁(默认)
I、线程的请求可以 在等待线程的队列中向前跳跃,获得该锁;
II、线程只有当锁被占用时才会等待;
b,公平锁
I、如果锁已被线程占用,新的线程请求会加入到等待队列,线程必须 按顺序获取;
4、synchronized与ReentrantLock选择
4.1、在内部锁不能满足使用时,ReentrantLock才被作为更高级的工具;
4.2、当你需要以下高级特性时,才应该使用:
a,可定时、可轮询的锁获取;
b,可中断的锁获取;
c,公平队列;
d,非块结构的锁;
5、读写锁
5.1、ReentrantLock实现了标准的互斥锁(一次最多只有一个线程能够持有相同的lock);
5.2、互斥锁 过分地限制了并发性,避免了"写/写"、"写/读"、"读/读"操作;
读写锁 :一个资源可 被多个读者访问(或 被一个写者访问 [2者不能同时进行]);
5.3、jdk提供了 ReadWriteLock、ReentrantReadWriteLock:
a,ReentrantReadWriteLock 提供了 可重入的加锁语义;
b,ReentrantReadWriteLock 可被 构造为 非公平、公平锁:
公平锁:
选择权 交给 等待时间最长的线程;
如果 锁由读者获得,而 另一个线程请求写入锁,那么 不允许读者获得读取锁,直到 写者被受理,且已释放写入锁;
非公平锁:
线程运行访问的顺序不定;
由 写者降级为读者 允许的,读者升级为写者不允许;
c,ReentrantReadWriteLock 的 写入锁 有 唯一的所有者 , 且 只能被 获得了该锁的线程释放;
JavaSE---显式锁的更多相关文章
- 深入理解Java内置锁和显式锁
synchronized and Reentrantlock 多线程编程中,当代码需要同步时我们会用到锁.Java为我们提供了内置锁(synchronized)和显式锁(ReentrantLock)两 ...
- Java并发编程之显式锁机制
我们之前介绍过synchronized关键字实现程序的原子性操作,它的内部也是一种加锁和解锁机制,是一种声明式的编程方式,我们只需要对方法或者代码块进行声明,Java内部帮我们在调用方法之前和结束时加 ...
- java并发多线程显式锁Condition条件简介分析与监视器 多线程下篇(四)
Lock接口提供了方法Condition newCondition();用于获取对应锁的条件,可以在这个条件对象上调用监视器方法 可以理解为,原本借助于synchronized关键字以及锁对象,配备了 ...
- java 并发多线程显式锁概念简介 什么是显式锁 多线程下篇(一)
目前对于同步,仅仅介绍了一个关键字synchronized,可以用于保证线程同步的原子性.可见性.有序性 对于synchronized关键字,对于静态方法默认是以该类的class对象作为锁,对于实例方 ...
- “全栈2019”Java多线程第三十二章:显式锁Lock等待唤醒机制详解
难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java多 ...
- “全栈2019”Java多线程第三十一章:中断正在等待显式锁的线程
难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java多 ...
- Java编程的逻辑 (71) - 显式锁
本系列文章经补充和完善,已修订整理成书<Java编程的逻辑>,由机械工业出版社华章分社出版,于2018年1月上市热销,读者好评如潮!各大网店和书店有售,欢迎购买,京东自营链接:http: ...
- 显式锁(二)Lock接口与显示锁介绍
一.显式锁简介 显式锁,这个叫法是相对于隐式锁synchronized而言的,加锁和解锁都要用户显式地控制.显示锁Lock是在Java5中添加到jdk的,同synchronized一样,这也是一 ...
- 显式锁(三)读写锁ReadWriteLock
前言: 上一篇文章,已经很详细地介绍了 显式锁Lock 以及 其常用的实现方式- - ReetrantLock(重入锁),本文将介绍另一种显式锁 - - 读写锁ReadWriteLock. ...
- 显式锁(四)Lock的等待通知机制Condition
任意一个Java对象,都拥有一组监视器方法(定义在根类Object上),主要包括:wait( ).wait(long timeout).notify().notifyAll()方法:这些方法与关 ...
随机推荐
- Spring mvc注解说明
编号 注解 说明 位置 备注 1 @Controller 将类变成Spring Bean 类 现阶段 @Controller . @Service 以及 @Repository 和 @Componen ...
- sql语句实现行转列的3种方法实例
sql语句实现行转列的3种方法实例 一般在做数据统计的时候会用到行转列,假如要统计学生的成绩,数据库里查询出来的会是这样的,但这并不能达到想要的效果,所以要在查询的时候做一下处理,下面话不多说了,来一 ...
- laravel 使用PhantomMagick导出pdf ,在Linux下安装字体
git项目地址:https://github.com/anam-hossain/phantommagick sudo apt-get -y install fontconfig xfonts-util ...
- cocos2dx基础篇(15) 列表视图CCTableView
[3.x] (1)去掉 "CC" (2)TableViewCell 中: > unsigned int getIdx() 返回类型改为 ssize_t(类型为 long) ( ...
- VM CentOS建立共享文件夹实现VS Code在windows环境下go开发,在centos环境里编译
简介 笔记本没办法更换系统,但是开发又必须在linux环境下进行,直接在vm界面环境下开发,卡的都蒙13.无奈之下想到这个法子,来解决现有尴尬的局面>>> 共分3个部分安装: (1) ...
- 实验3&总结5
老师:lijin2019,助教:晨晨果 提交作业 实验三 String类的应用 实验目的 掌握类String类的使用: 学会使用JDK帮助文档: 实验内容 1.已知字符串:"this is ...
- 【监控实践】【4.2】perfmon监控性能计数器(基于typeperf命令)
关键词:typeperf typeperf 命令 使用示例: 案例1:#使用typeperf收集windows cpu.内存.硬盘性能 #使用typeperf收集windows cpu.内存.硬盘性能 ...
- Windows系统里Oracle 11g R2 Client(64bit)的下载与安装
环境: windows10系统(64位) 最好先安装jre或jdk(此软件用来打开oracle自带的可视化操作界面,不装也没关系:可以安装plsql,或者直接用命令行操作) Oracle 11g 是仅 ...
- 安装CentOS7虚拟机
基础环境 Windows 10 VMware Workstation 1.下载CentOS7镜像 https://www.centos.org/download/ 此次安装使用的版本为: CentOS ...
- Highways POJ-1751 最小生成树 Prim算法
Highways POJ-1751 最小生成树 Prim算法 题意 有一个N个城市M条路的无向图,给你N个城市的坐标,然后现在该无向图已经有M条边了,问你还需要添加总长为多少的边能使得该无向图连通.输 ...