java之两种并发模型 以及 锁

博客围绕并行与分布式编程展开,介绍了复杂软件系统构造。在并发部分,阐述共享内存和消息传递两种编程模型。重点讲解Java锁,包括内置锁概念、互斥特性,还说明了同步和锁的用法及实现方法,如用synchronized修饰、使用wait等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

并行与分布式编程

关注的是复杂软件系统的构造,“复杂”是指多线程、分布式与GUI程序
在锁与同步这一节中,详细介绍了如何设计线程安全的ADT

并发

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

• 在共享内存模型中 :并发模块通过在内存中读取和写入共享可变对象来进行交互。在单个Java进程中创建多个线程是我们共享内存并发的主要示例。
在消息传递模型中:并发模块通过通信通道相互发送不可变消息进行交互。该通信通道可以通过网络连接不同的计算机,如我们的一些初始示例:Web浏览,即时消息等。

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

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

Java的内置锁:每个java对象都可以用做一个实现同步的锁,这些锁成为内置锁。线程进入同步代码块或者代码方法的时候会自动获得该锁,在退出同步代码块或者方法的时候则会释放该锁。获得内置锁的唯一途径就是进入这个锁的保护的同步代码块或者方法。
Java内置锁是一个互斥锁:就是最多一个程序能够得到这个锁。当多个线程想要对某个mutable类型的ADT操作时,就是修改它的值时,锁能够劫持这些线程的操作,阻塞他们,只有之前的线程结束调用时,释放这个锁,后面的线程才能获得该锁,否则一直等待下去。

用法

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

synchronized 关键词修饰

wait、notify、notifyAll的使用

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值