Java并发包下锁学习第一篇:介绍及学习安排
Java并发包下锁学习第一篇:介绍及学习安排
在Java并发编程中,实现锁的方式有两种,分别是:可以使用同步锁(synchronized关键字的锁),还有lock接口下的锁。从今天起,凯哥将带领大家一起豪华参观(详细讲解)在Java并发包(JUC)下locks包下的体系结构。
在这个系列中,我们将会学习并发包下锁实现的原理(我们将跟着源码来分析)、什么是可重入锁、公平锁和非公平锁怎么定义的、为什么synchronized关键字的锁和ReentrantLock默认会选择非公平锁?读写锁和独占锁的比较、跟着源码我们来分析读写锁等和锁相关的知识。学完这个系列教程后,大家将对并发锁有更新的理解,欢迎大家一起学习。
本篇是《凯哥(凯哥Java:kagejava)并发编程学习》系列之《Lock系列》教程的第一篇:《Java并发包下锁学习第一篇》
本文主要内容:java中锁定义及在jdk5以后的并发包(JUC)下锁相关的类及类关系图;怎么学习JUC下锁
凯哥讲解一般步骤:先举生活中的例子,然后从例子中总结,然后在用代码演示。经过这三个步骤来加深大家的印象。
一:锁的理解
在多线程场景下,多个线程要操作同一个资源,这个被竞争的资源就是共享资源。当同时有多个线程一起竞争共享资源的时候,如果一个线程竞争到了这个资源,就需要使用一个手段或者是技术通知其他线程,这个资源已经被占用着,其他线程需要等待才可以。基于这种思想,在我们现实生活中,如何让其他人知道某个东西是你的呢?贴上你的名字、打上标识或者是用一把锁锁着。这样别人就竞争不了了。锁就是这个通知其他人(或线程)的一种手段。所以,在多线程环境下,就是用了这种技术来实现对共享资源的控制。
二:JUC下locks包下体系
我们先来看看JUC下的locks包都有哪些类或接口。
JUC包下锁相关的类:
上图中类之间的关系可以简单如下图:
锁之间类图关系:
更简单明了的如下图:
三:类介绍
AbstractOwnableSynchronizer:队列同步器。
该类是用来构建锁或者其他同步组件的基础框架的顶级抽象类。有两个子类
AbstractQueuedLongSynchronizer:是AbstractQueuedSynchronizer类的另一个版本类。区别就在原AbstractQueuedLongSynchronizer类里面状态码使用Long类型的而非int类型的。凯哥在以后文章中将详细介绍AbstractQueuedSynchronizer类的。
AbstractQueuedSynchronizer:队列同步器。
使用比较多的。是构建锁或者其他同步组建的基础框架。其通过一个int成员变量来表示同步状态的。通过内部类Node来实现FIFO(first-in-first-out:即先进先出)的队列来完成获取资源线程排队的操作。
Lock:
排他锁的顶级接口。
RenntrantLock:
Lock的实现类。可重入锁。内部有公平锁和非公平锁两个内部类。
ReadWriteLock:
读写锁的顶级接口
ReentrantReadWriteLock:
读写锁的子类。内部有读锁和写锁两个内部类来控制着读写分离操作的。
LockSupport:
当要执行阻塞或者是唤醒一个线程的时候,都会使用到lockSupport这个工具类来实现的。
Condition:
监视对象。与lock对象配合使用来实现等待/通知模式
四:学习安排
通过上面介绍我们对并发包下的locks包有所了解了。在接下来的学习中,我们将会按照上面类介绍的顺序来学习。先学习同步队列,跟着源码来分析主要API;在学习排他锁;然后再学习读写锁;最后学习后面两个类。
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
Σco时间丨智能时代,闪存普惠千行百业
【51CTO.com原创稿件】虽然2020年新春伊始的这场新冠肺炎疫情让技术人群放弃了聚会,减少了面对面沟通,但他们对于学习和交流的渴望从未停歇过。为此华为特别推出了#Σco时间#系列栏目,以线上直播+互动的形式,共话技术变革与行业转型。 华为在#Σco时间#直播平台,联合智能数据基础设施“学数派”举办了以“智能时代,闪存普惠千行百业”为主题的2020年华为全闪存技术论坛,华为存储行业解决方案架构师杜宇�F、华为数据存储高级营销经理高俊霞、华为数据存储解决方案高级工程师周辉三位演讲嘉宾从存储未来趋势、技术、实践、案例和实验室实测演示等多维度,深度解读了全闪存如何使能千行百业,实现全场景普惠,助力各行业客户的IT系统实现全在线、全实时、全天候业务响应。2000+位网友在线“围观”了这场技术论坛,并对华为演讲内容“干货”给予了高度认可。 智能时代,全闪存释放数据力量普惠千行百业 华为存储行业解决方案架构师杜宇�F在演讲时首先表示,在今年3月初,国家发布了面向7大新基建的布局,面向未来10年,支撑全社会的高速发展。在7大新基建的激发下,智慧城市、智慧医疗、智慧教育、智慧港口等领域都会进入发展...
- 下一篇
程序员的进阶课-架构师之路 - 数组
从这一节开始,我们就要正式进去数据结构的世界了,那么第一个是什么呢,就是我们的数组。在我想写数组的时候,我的第一印象是去看它的源码,很可惜,数组的实现太特殊了,找了很久,我没有找到它的源码,带着这样的思考,我就开始了Java中数组的挖掘。Wow,真香!一、Java中数组的介绍 数组是一种最简单的复合数据类型,它是有序数据的集合,数组中的每个元素具有相同的数据类型,可以用一个统一的数组名和不同的下标来唯一确定数组中的元素。根据数组的维度,可以将其分为一维数组、二维数组和多维数组等。一定要注意,数组只能存放同一种数据类型(Object类型数组除外)。二、数组是一个引用类型吗? 先给答案,是的,没有任何疑问。注意,数组也是一种数据类型,它本身是一种引用类型。数组是一种大小固定的数据结构,对线性表的所有操作都可以通过数组来实现。虽然数组一旦创建之后,它的大小就无法改变了,但是当数组不能再存储线性表中的新元素时,我们可以创建一个新的大的数组来替换当前数组。这样就可以使用数组实现动态的数据结构。如何验证? 定义一个数组,发现它拥有Object类的所有方法。 根据这个例子,其实大家已经看出来了,数组...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
-
Docker使用Oracle官方镜像安装(12C,18C,19C)
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- CentOS8编译安装MySQL8.0.19
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- MySQL8.0.19开启GTID主从同步CentOS8
- CentOS7,8上快速安装Gitea,搭建Git服务器
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
推荐阅读
最新文章
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
- CentOS7,CentOS8安装Elasticsearch6.8.6
- SpringBoot2初体验,简单认识spring boot2并且搭建基础工程
- CentOS6,CentOS7官方镜像安装Oracle11G
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- 设置Eclipse缩进为4个空格,增强代码规范
- Mario游戏-低调大师作品
- MySQL8.0.19开启GTID主从同步CentOS8
- Windows10,CentOS7,CentOS8安装MongoDB4.0.16