多线程通信

简介: 多线程通信

多线程通信

多线程通信即多线程交互问题,举个例子:线程一网上下载音乐,线程二播放下载的音乐。

交互问题都可以归类为生产者和消费者问题:

生产者生产时消费者休眠,生产好后生产者唤醒消费者然后生产者休眠,消费者消费完之后再唤醒生产者然后消费者休眠,生产者还是工作。

在这里生产者和消费者各代表一个线程。

在Object类中有几个方法是用于多线程通信问题:

image.png

举例子

下面我们举一个关于生产者与消费者的例子:

厨师为生产者,服务员为消费者;

image.png


image.png

image.png

这里输出的结果是会出现问题,如图输出结果的一部分:

image.png

可以看到饭变成了有味,菜变成了无味。

原因是:setNameAndsetTaste中name和taste的设置中间隔了100毫秒,也就是在name设置好之后,服务员就过来把name和上次设置的,这次还未来得及从新设置的taste通过调用get()取走。

如何做:

使用线程安全解决?

此方法是行不通的,Cook和Waiter虽然操作的同一个堆内存,通过锁一个线程进去另外一个进不来,但是线程安全是非公平锁,有可能Cook出来后又立马抢到了锁又进去了一次,这回导致前面一次Cook产生的数据Waiter无法及时拿到。

只能使用消费者和生产者分别休眠进行解决。实现过程如下所示:

 

中间使用notifyAll和wait方法实现对线程的启动和休眠

目录
打赏
0
0
0
0
1
分享
相关文章
|
7月前
|
实现Java多线程中的线程间通信
实现Java多线程中的线程间通信
从菜鸟到大神:JAVA多线程通信的wait()、notify()、notifyAll()之旅
【6月更文挑战第21天】Java多线程核心在于wait(), notify(), notifyAll(),它们用于线程间通信与同步,确保数据一致性。wait()让线程释放锁并等待,notify()唤醒一个等待线程,notifyAll()唤醒所有线程。这些方法在解决生产者-消费者问题等场景中扮演关键角色,是程序员从新手到专家进阶的必经之路。通过学习和实践,每个程序员都能在多线程编程的挑战中成长。
72 6
|
4月前
|
[Java]线程生命周期与线程通信
本文详细探讨了线程生命周期与线程通信。文章首先分析了线程的五个基本状态及其转换过程,结合JDK1.8版本的特点进行了深入讲解。接着,通过多个实例介绍了线程通信的几种实现方式,包括使用`volatile`关键字、`Object`类的`wait()`和`notify()`方法、`CountDownLatch`、`ReentrantLock`结合`Condition`以及`LockSupport`等工具。全文旨在帮助读者理解线程管理的核心概念和技术细节。
57 1
[Java]线程生命周期与线程通信
|
3月前
|
JAVA多线程通信:为何wait()与notify()如此重要?
在Java多线程编程中,`wait()` 和 `notify()/notifyAll()` 方法是实现线程间通信的核心机制。它们通过基于锁的方式,使线程在条件不满足时进入休眠状态,并在条件满足时被唤醒,从而确保数据一致性和同步。相比其他通信方式,如忙等待,这些方法更高效灵活。 示例代码展示了如何在生产者-消费者模型中使用这些方法实现线程间的协调和同步。
57 3
|
4月前
|
Java多线程通信新解:本文通过生产者-消费者模型案例,深入解析wait()、notify()、notifyAll()方法的实用技巧
【10月更文挑战第20天】Java多线程通信新解:本文通过生产者-消费者模型案例,深入解析wait()、notify()、notifyAll()方法的实用技巧,包括避免在循环外调用wait()、优先使用notifyAll()、确保线程安全及处理InterruptedException等,帮助读者更好地掌握这些方法的应用。
45 1
Java多线程中的`wait()`、`notify()`和`notifyAll()`方法,探讨了它们在实现线程间通信和同步中的关键作用
本文深入解析了Java多线程中的`wait()`、`notify()`和`notifyAll()`方法,探讨了它们在实现线程间通信和同步中的关键作用。通过示例代码展示了如何正确使用这些方法,并分享了最佳实践,帮助开发者避免常见陷阱,提高多线程程序的稳定性和效率。
85 1
|
4月前
|
在Java多线程编程中,`wait()` 和 `notify()/notifyAll()` 方法是线程间通信的核心机制。
在Java多线程编程中,`wait()` 和 `notify()/notifyAll()` 方法是线程间通信的核心机制。它们通过基于锁的方式,使线程在条件不满足时进入休眠状态,并在条件成立时被唤醒,从而有效解决数据一致性和同步问题。本文通过对比其他通信机制,展示了 `wait()` 和 `notify()` 的优势,并通过生产者-消费者模型的示例代码,详细说明了其使用方法和重要性。
71 1
|
8月前
|
Java Socket编程与多线程:提升客户端-服务器通信的并发性能
【6月更文挑战第21天】Java网络编程中,Socket结合多线程提升并发性能,服务器对每个客户端连接启动新线程处理,如示例所示,实现每个客户端的独立操作。多线程利用多核处理器能力,避免串行等待,提升响应速度。防止死锁需减少共享资源,统一锁定顺序,使用超时和重试策略。使用synchronized、ReentrantLock等维持数据一致性。多线程带来性能提升的同时,也伴随复杂性和挑战。
143 0
|
4月前
多线程通信和同步的方式有哪些?
【10月更文挑战第6天】
203 0