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---显式锁的更多相关文章

  1. 深入理解Java内置锁和显式锁

    synchronized and Reentrantlock 多线程编程中,当代码需要同步时我们会用到锁.Java为我们提供了内置锁(synchronized)和显式锁(ReentrantLock)两 ...

  2. Java并发编程之显式锁机制

    我们之前介绍过synchronized关键字实现程序的原子性操作,它的内部也是一种加锁和解锁机制,是一种声明式的编程方式,我们只需要对方法或者代码块进行声明,Java内部帮我们在调用方法之前和结束时加 ...

  3. java并发多线程显式锁Condition条件简介分析与监视器 多线程下篇(四)

    Lock接口提供了方法Condition newCondition();用于获取对应锁的条件,可以在这个条件对象上调用监视器方法 可以理解为,原本借助于synchronized关键字以及锁对象,配备了 ...

  4. java 并发多线程显式锁概念简介 什么是显式锁 多线程下篇(一)

    目前对于同步,仅仅介绍了一个关键字synchronized,可以用于保证线程同步的原子性.可见性.有序性 对于synchronized关键字,对于静态方法默认是以该类的class对象作为锁,对于实例方 ...

  5. “全栈2019”Java多线程第三十二章:显式锁Lock等待唤醒机制详解

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java多 ...

  6. “全栈2019”Java多线程第三十一章:中断正在等待显式锁的线程

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java多 ...

  7. Java编程的逻辑 (71) - 显式锁

    ​本系列文章经补充和完善,已修订整理成书<Java编程的逻辑>,由机械工业出版社华章分社出版,于2018年1月上市热销,读者好评如潮!各大网店和书店有售,欢迎购买,京东自营链接:http: ...

  8. 显式锁(二)Lock接口与显示锁介绍

    一.显式锁简介    显式锁,这个叫法是相对于隐式锁synchronized而言的,加锁和解锁都要用户显式地控制.显示锁Lock是在Java5中添加到jdk的,同synchronized一样,这也是一 ...

  9. 显式锁(三)读写锁ReadWriteLock

    前言:   上一篇文章,已经很详细地介绍了 显式锁Lock 以及 其常用的实现方式- - ReetrantLock(重入锁),本文将介绍另一种显式锁 - - 读写锁ReadWriteLock.    ...

  10. 显式锁(四)Lock的等待通知机制Condition

       任意一个Java对象,都拥有一组监视器方法(定义在根类Object上),主要包括:wait( ).wait(long timeout).notify().notifyAll()方法:这些方法与关 ...

随机推荐

  1. 【linux】cp 批量复制文件

    [需求]: 有2个文件夹a,b,现在需要将a文件夹下的所有文件(aa.py,a2.py,a3.py)都复制到b文件夹(空文件夹) [解决办法]: 首先想到的是使用正则表达式,但是发现在linux中,只 ...

  2. prism Callback应用

    Mock<IEventAggregator> mockEventAggregator; Mock<MyEvent> mockEvent; mockEventAggregator ...

  3. for...in 、Object.keys 、 Object.getOwnPropertyNames

    个人总结: 1.for...in 遍历的是对象的可枚举,非Symbol属性(包括自身和原型上的) 2.Object.keys 返回一个数组,是对象自身的可枚举属性 (非Symbol) 3.Object ...

  4. node.js ffmpeg-concat 命令行形式处理多个视频的过度效果

    ffmpeg-concat 是利用 gl-transitions 处理多个视频的过度效果.详细说明参见 https://github.com/transitive-bullshit/ffmpeg-co ...

  5. 模态框——angular

    ui-bootstrap-tpls.js库 $uibModal服务 $uibModalInstance服务 一.在angular中应用modal $uibModal 使用方法:直接注入到控制器中. . ...

  6. c语言字串指针 char*

    c语言中 char* 不仅能存字符串,还能存二进制数据,所以它的用途因使用者而定. char* 在很多使用场景下,是需要存储ascii码为0的元素的,这样就必须注意一个问题,那就是char*的长度. ...

  7. Django-DRF组件学习-预备知识

    1.web开发应用模式 在开发Web应用中,有两种应用模式: 1.1 前后端不分离 所谓的前后端不分离,就是前后端数据都在同一个服务器中,前端的样式以及页面渲染都由后端一次性渲染出来在前端浏览器中展示 ...

  8. 应用安全 - Web框架 - Apache Flink - 漏洞汇总

    SSV ID:SSV-98101 -- 类型: 文件上传导致远程代码执行   flink下载: https://www.apache.org/dyn/closer.lua/flink/flink-1. ...

  9. MySQL服务意外停止

    先说一下,发现MySQL服务停了,启动就又好了,但是好奇服务意外停止的原因,所以看了一下MySQL的错误日志. 但是到底是哪个错误导致MySQL服务意外终止,还没有定论,故有了此篇文章,还望知道原因的 ...

  10. javascript学习笔记--经典继承、组合继承、原型式继承、寄生继承以及寄生组合继承

    经典继承 js中实现经典继承的方式是通过构造函数来实现的,即在子类中对父类调用call方法. function Geometric() { this.time = ""; this ...