|
|
51CTO旗下网站
|
|
移动端

并发编程中的线程间通信

线程通信的目标是使线程间能够互相发送信号。另一方面,线程通信使线程能够等待其他线程的信号。

作者:T知识课堂来源:今日头条|2019-09-16 08:45

【大咖·来了 第7期】10月24日晚8点观看《智能导购对话机器人实践》

线程通信的目标是使线程间能够互相发送信号。另一方面,线程通信使线程能够等待其他线程的信号。

线程通信常用的方式有:

  • wait/notify 等待
  • Volatile 内存共享
  • CountDownLatch 并发工具
  • 使用 ReentrantLock 结合 Condition
  • 基本LockSupport实现线程间的阻塞和唤醒

方式一:使用 volatile 关键字

基于 volatile 关键字来实现线程间相互通信是使用共享内存的思想,大致意思就是多个线程同时监听一个变量,当这个变量发生变化的时候 ,线程能够感知并执行相应的业务。这也是最简单的一种实现方式

并发编程中的线程间通信

运行结果为:

并发编程中的线程间通信

方式二:使用Object类的wait() 和 notify() 方法

众所周知,Object类提供了线程间通信的方法:wait()、notify()、notifyaAl(),它们是多线程通信的基础,而这种实现方式的思想自然是线程间通信。

注意: wait和 notify必须配合synchronized使用,wait方法释放锁,notify方法不释放锁

并发编程中的线程间通信

运行结果为

并发编程中的线程间通信

由打印结果截图可知,在线程A发出notify()唤醒通知之后,依然是走完了自己线程的业务之后,线程B才开始执行,这也正好说明了,notify()方法不释放锁,而wait()方法释放锁。

方式三:使用JUC工具类 CountDownLatch

jdk1.5之后在java.util.concurrent包下提供了很多并发编程相关的工具类,简化了我们的并发编程代码的书写,***CountDownLatch***基于AQS框架,相当于也是维护了一个线程间共享变量state

并发编程中的线程间通信

运行结果为:

并发编程中的线程间通信

方式四:使用 ReentrantLock 结合 Condition

并发编程中的线程间通信

运行结果为:

并发编程中的线程间通信

显然这种方式使用起来并不是很好,代码编写复杂,而且线程B在被A唤醒之后由于没有获取锁还是不能立即执行,也就是说,A在唤醒操作之后,并不释放锁。这种方法跟 Object 的 wait() 和 notify() 一样。

方式五:基本LockSupport实现线程间的阻塞和唤醒

LockSupport 是一种非常灵活的实现线程间阻塞和唤醒的工具,使用它不用关注是等待线程先进行还是唤醒线程先运行,但是得知道线程的名字。

并发编程中的线程间通信

运行结果

并发编程中的线程间通信

【编辑推荐】

  1. 一篇文章为你图解Kubernetes网络通信原理
  2. TCP/IP协议族体系结构--网络通信
  3. 5G通信需千万基站!这么多咋建
  4. 相比较于不安全的HTTP,HTTPS是怎么保证网络通信安全的
  5. HTTPS 中SSL协议通信过程及对称加密和非对称加密详解
【责任编辑:武晓燕 TEL:(010)68476606】

点赞 0
分享:
大家都在看
猜你喜欢

订阅专栏+更多

用Python玩转excel

用Python玩转excel

让重复操作傻瓜化
共3章 | DE8UG

119人订阅学习

AI入门级算法

AI入门级算法

算法常识
共22章 | 周萝卜123

113人订阅学习

这就是5G

这就是5G

5G那些事儿
共15章 | armmay

120人订阅学习

读 书 +更多

JSP应用开发详解(第二版)

本书结合JSP和Servlet的最新规范,从基本的语法和规范入手,以经验为后盾,以实用为目标,以实例为导向,以实践为指导,深入浅出地讲解了JS...

订阅51CTO邮刊

点击这里查看样刊

订阅51CTO邮刊

51CTO服务号

51CTO官微