java关于并发模型中的两种锁知识点详解
1、悲观锁
悲观锁假设最坏的情况(如果果你不锁门,那么捣蛋鬼就会闯入并搞得一团糟),只有在确保其他线程不受干扰(获得正确的锁)的情况下才能执行。
一般实现如独占锁等。
安全性更高,但中低并发性效率更低。
2、乐观锁
乐观锁通过冲突检查机制判断更新过程中是否存在其他线程干扰。如果存在,操作将失败,重试(也可以不重试)。
CAS等常见实现。
一些乐观锁削弱了一致性,但在中低并发性下效率大大提高。
知识点扩展:
并行与分布式编程
关注的是复杂软件系统的构造,“复杂”是指多线程、分布式与GUI程序
在锁与同步这一节中,详细介绍了如何设计线程安全的ADT
并发
在我们的并发介绍中,我们看到了两种并发编程模型:共享内存和消息传递。
• 在共享内存模型中 :并发模块通过在内存中读取和写入共享可变对象来进行交互。在单个Java进程中创建多个线程是我们共享内存并发的主要示例。
• 在消息传递模型中:并发模块通过通信通道相互发送不可变消息进行交互。该通信通道可以通过网络连接不同的计算机,如我们的一些初始示例:Web浏览,即时消息等。
锁
对于锁,这是Java语言提供的内嵌机制,每个Object都有相关联的lock;
首先来了解一下java锁的相关概念
Java的内置锁:每个java对象都可以用做一个实现同步的锁,这些锁成为内置锁。线程进入同步代码块或者代码方法的时候会自动获得该锁,在退出同步代码块或者方法的时候则会释放该锁。获得内置锁的唯一途径就是进入这个锁的保护的同步代码块或者方法。
Java内置锁是一个互斥锁:就是最多一个程序能够得到这个锁。当多个线程想要对某个mutable类型的ADT操作时,就是修改它的值时,锁能够劫持这些线程的操作,阻塞他们,只有之前的线程结束调用时,释放这个锁,后面的线程才能获得该锁,否则一直等待下去。
用法
同步和锁:阻止了多线程在同一时间内对可变数据的共享操作,即程序员来负责多线程之间对mutable数据的共享操作,通过”同步”策略,避免多线程同时访问数据,使用锁机制,获取对数据的独家mutation权,其他线程被阻塞,不得访问,即不可修改。
Java同步锁实现方法
synchronized 关键词修饰
wait、notify、notifyAll的使用
相关文章
Spring Boot 集成并开发 Sa-token示例详解
Sa-token是一款高可用的权限认证框架,他带我们用最简化的配置完成用 spring security 需要进行大量配置的才能完成的工作,这篇文章主要介绍了Spring Boot 集成并开发 Sa-token,需要的朋友可以参考下2023-06-06SpringBoot+RabbitMQ方式收发消息的实现示例
这篇文章主要介绍了SpringBoot+RabbitMQ方式收发消息的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2020-09-09SpringBoot将logback替换成log4j2的操作步骤
文章介绍了如何在SpringBoot项目中将默认的日志框架logback替换为log4j2,以利用log4j2的高性能异步日志记录特性,特别是通过Disruptor实现的无锁化队列,提高了日志处理速度,同时,文章提供了详细的配置步骤,需要的朋友可以参考下2024-10-10
最新评论