iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Java多线程之多种锁和阻塞队列
  • 481
分享到

Java多线程之多种锁和阻塞队列

2024-04-02 19:04:59 481人浏览 独家记忆

Python 官方文档:入门教程 => 点击学习

摘要

目录一、悲观锁和乐观锁1.1. 乐观锁1.2. 悲观锁二、公平锁和非公平锁三、可重入锁(递归锁)四、自旋锁五、独占锁(写)/共享锁(读)六、什么是阻塞队列?七、阻塞队列(Blocki

一、悲观锁和乐观锁

1.1. 乐观锁

顾名思义,就是很乐观,每次去拿数据的时候都认为别人不会修改,所以不会上锁,但是在更新的时候会判断一下在此期间别人有没有去更新这个数据,可以使用版本号等机制。

乐观锁适用于多读的应用类型,乐观锁在Java中是通过使用无锁编程来实现,最常采用的是CAS算法,Java原子类中的递增操作就通过CAS自旋实现的。

CAS全称 Compare And Swap(比较与交换),是一种无锁算法。在不使用锁(没有线程被阻塞)的情况下实现多线程之间的变量同步。java.util.concurrent包中的原子类就是通过CAS来实现了乐观锁。

1.2. 悲观锁

总是假设最坏的情况,每次去拿数据的时候都认为别人会修改,所以每次在拿数据的时候都会上锁,这样别人想拿这个数据就会阻塞直到它拿到锁。

二、公平锁和非公平锁

在这里插入图片描述
在这里插入图片描述

三、可重入锁(递归锁)

先看官网的解释翻译后的

在这里插入图片描述

看不太懂,那么我们结合一下下面的案例就行了。

在这里插入图片描述

两个同步方法01和02,都是被锁住的,当我们运行01的时候,一旦获取的01的锁,那么02的锁也可以被自动获取。

在这里插入图片描述

补充:lock和unlock只要配对使用,就不会有问题。

四、自旋锁

在这里插入图片描述

其实CAS底层就是用 Unsafe类+CAS(自旋) 实现的,CAS底层有一个do while语句,循环比较在主存中的值是否等于期望值。

五、独占锁(写)/共享锁(读)

在这里插入图片描述

读归读,写归写,读和写可以同时进行。

六、什么是阻塞队列?

队列中放着数据,一个线程生产,一个线程获取。

在这里插入图片描述
在这里插入图片描述

七、阻塞队列(BlockingQueue)

在这里插入图片描述

阻塞队列有多少实现类呢?

在这里插入图片描述

到此这篇关于Java多线程之多种锁和阻塞队列的文章就介绍到这了,更多相关java多种锁和阻塞队列内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Java多线程之多种锁和阻塞队列

本文链接: https://www.lsjlt.com/news/127937.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作