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

2025-05-29 0 64

1、悲观

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

一般实现如独占等。

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

2、乐观

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

CAS等常见实现。

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

知识点扩展:

并行与分布式编程

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

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

并发

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

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

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

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

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

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

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

用法

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

Java同步实现方法

synchronized 关键词修饰

wait、notify、notifyAll的使用

原文链接:https://www.py.cn/java/jichu/28751.html

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 java关于并发模型中的两种锁知识点详解 https://www.kuaiidc.com/108254.html

相关文章

发表评论
暂无评论