java关于并发模型中的两种锁知识点详解

 更新时间:2021年04月02日 08:29:43   作者:小妮浅浅  
在本篇文章了小编给大家整理的是一篇关于java关于并发模型中的两种锁知识点详解内容,有兴趣的朋友们可以学习下。

1、悲观锁

悲观锁假设最坏的情况(如果果你不锁门,那么捣蛋鬼就会闯入并搞得一团糟),只有在确保其他线程不受干扰(获得正确的锁)的情况下才能执行。

一般实现如独占锁等。

安全性更高,但中低并发性效率更低。

2、乐观锁

乐观锁通过冲突检查机制判断更新过程中是否存在其他线程干扰。如果存在,操作将失败,重试(也可以不重试)。

CAS等常见实现。

一些乐观锁削弱了一致性,但在中低并发性下效率大大提高。

知识点扩展:

并行与分布式编程

关注的是复杂软件系统的构造,“复杂”是指多线程、分布式与GUI程序

在锁与同步这一节中,详细介绍了如何设计线程安全的ADT

并发

在我们的并发介绍中,我们看到了两种并发编程模型:共享内存和消息传递。

• 在共享内存模型中 :并发模块通过在内存中读取和写入共享可变对象来进行交互。在单个Java进程中创建多个线程是我们共享内存并发的主要示例。

• 在消息传递模型中:并发模块通过通信通道相互发送不可变消息进行交互。该通信通道可以通过网络连接不同的计算机,如我们的一些初始示例:Web浏览,即时消息等。


对于锁,这是Java语言提供的内嵌机制,每个Object都有相关联的lock;

首先来了解一下java锁的相关概念

Java的内置锁:每个java对象都可以用做一个实现同步的锁,这些锁成为内置锁。线程进入同步代码块或者代码方法的时候会自动获得该锁,在退出同步代码块或者方法的时候则会释放该锁。获得内置锁的唯一途径就是进入这个锁的保护的同步代码块或者方法。

Java内置锁是一个互斥锁:就是最多一个程序能够得到这个锁。当多个线程想要对某个mutable类型的ADT操作时,就是修改它的值时,锁能够劫持这些线程的操作,阻塞他们,只有之前的线程结束调用时,释放这个锁,后面的线程才能获得该锁,否则一直等待下去。

用法

同步和锁:阻止了多线程在同一时间内对可变数据的共享操作,即程序员来负责多线程之间对mutable数据的共享操作,通过”同步”策略,避免多线程同时访问数据,使用锁机制,获取对数据的独家mutation权,其他线程被阻塞,不得访问,即不可修改。

Java同步锁实现方法

synchronized 关键词修饰

wait、notify、notifyAll的使用

相关文章

  • Java阻塞队列BlockingQueue详解

    Java阻塞队列BlockingQueue详解

    这篇文章主要介绍了Java阻塞队列BlockingQueue,文章通过队列的类型展开详细的内容介绍,具有一定的参考价值,需要的朋友可以参考一下
    2022-07-07
  • Spring Boot 集成并开发 Sa-token示例详解

    Spring Boot 集成并开发 Sa-token示例详解

    Sa-token是一款高可用的权限认证框架,他带我们用最简化的配置完成用 spring security 需要进行大量配置的才能完成的工作,这篇文章主要介绍了Spring Boot 集成并开发 Sa-token,需要的朋友可以参考下
    2023-06-06
  • Javamelody监控不到sql的问题(亲测有效) ​

    Javamelody监控不到sql的问题(亲测有效) ​

    JavaMelody是用来在QA和实际运行生产环境中监控Java或Java EE应用程序服务器的一个开源框架,这篇文章主要介绍了Javamelody监控不到sql(亲测有效) ​,需要的朋友可以参考下
    2022-10-10
  • SpringBoot+RabbitMQ方式收发消息的实现示例

    SpringBoot+RabbitMQ方式收发消息的实现示例

    这篇文章主要介绍了SpringBoot+RabbitMQ方式收发消息的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • Springboot文件上传出现找不到指定系统路径的解决

    Springboot文件上传出现找不到指定系统路径的解决

    这篇文章主要介绍了Springboot文件上传出现找不到指定系统路径的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-08-08
  • SpringBoot将logback替换成log4j2的操作步骤

    SpringBoot将logback替换成log4j2的操作步骤

    文章介绍了如何在SpringBoot项目中将默认的日志框架logback替换为log4j2,以利用log4j2的高性能异步日志记录特性,特别是通过Disruptor实现的无锁化队列,提高了日志处理速度,同时,文章提供了详细的配置步骤,需要的朋友可以参考下
    2024-10-10
  • java中File类的构造函数及其方法

    java中File类的构造函数及其方法

    这篇文章主要介绍了java中File类的构造函数及其方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-06-06
  • Spring项目里将SQL语句写在.sql文件中的方法

    Spring项目里将SQL语句写在.sql文件中的方法

    这篇文章主要介绍了Spring项目里如何将SQL语句写在.sql文件中的方法,文中给出了详细的介绍和示例代码,相信对大家的学习或者工作具有一定的参考借鉴价值,有需要的朋友们下面来一起看看吧。
    2017-01-01
  • ElasticSearch 深度分页示例解析

    ElasticSearch 深度分页示例解析

    这篇文章主要为大家介绍了ElasticSearch 深度分页示例解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-02-02
  • Spring中@Primary注解的作用详解

    Spring中@Primary注解的作用详解

    这篇文章主要介绍了Spring中@Primary注解的作用详解,@Primary 注解是Spring框架中的一个注解,用于标识一个Bean作为默认的实现类,当存在多个实现类时,通过使用@Primary注解,可以指定其中一个作为默认的实现类,以便在注入时自动选择该实现类,需要的朋友可以参考下
    2023-10-10

最新评论