多线程---线程通信

本文深入探讨线程间的通信机制,包括wait/notify方法的使用,管道流实现的生产者-消费者模型,以及synchronized和FutureTask的应用。解析线程同步与通信的关键概念,如对象监视器、锁操作和唤醒机制。

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


1.使用wait/notify方法实现线程之间的通信

  • wait( ),notify( ),notifyAll( )都不属于Thread类,而是属于Object基础类,也就是每个对象都有这三个方法的功能,因为每个对象都有锁,锁是每个对象的基础,当然操作锁的方法也是最基础了。
  • 当需要调用以上的方法的时候,一定要对竞争资源进行加锁,如果不加锁的话,则会报 IllegalMonitorStateException 异常
  • 当想要调用wait( )进行线程等待时,必须要取得这个锁对象的控制权(对象监视器),一般是放到synchronized(obj)代码中。
  • 当wait()方法被调用时,该线程会是发出CPU资源,由其他线程进行竞争。
  • 调用了wait函数的线程会一直等待,直到有其他线程调用了同一个对象的notify或者notifyAll方法才能被唤醒,需要注意的是:被唤醒并不代表立即获得对象的锁。也就是说,一个线程调用了对象的wait方法后,他需要等待两件事情的发生:

             (1)有其他线程调用同一个对象的notify或者notifyAll方法(调用notify/notifyAll方法之前)
             (2)被唤醒之后重新获得对象的锁(调用notify/notifyAll方法之后)

  • 调用notify和notifyAll方法后,当前线程并不会立即放弃锁的持有权,而必须要等待当前同步代码块执行完才会让出锁(同上一条所表述的意思一样)。
  • 如果一个线程调用了某个对象的wait方法,但是后续并没有其他线程调用该对象的notify或者notifyAll方法,则该线程将会永远等下去…

编写测试代码如下:

运行结果:

2.管道通信
管道流主要用来实现两个线程之间的二进制数据的传播,下面以PipedInputStream类和PipedOutputStream类为例,实现生产者-消费者:
补充:PipedOutputStream和PipedInputStream是管道输出流和管道输入流,配合使用可以实现线程间通信。
  使用管道实现线程间通信的主要流程如下:建立输出流out和输入流in,将out和in绑定,out中写入的数据则会同步写入的in的缓冲区(实际情况是,out中写入数据就是往in的缓冲区写数据,out中没有数据缓冲区)。

 

代码弄丢了(๑ŐдŐ)b

3.其他线程通信方法
除了以上2中通信方式,还可以使用synchronized,以及FutureTask获取返回值实现线程之间的通信

代码弄丢了(๑ŐдŐ)b

 

转载于:https://www.cnblogs.com/red-evil/p/10039604.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值