Java——》线程间是如何通信的

推荐链接:

总结------》【Java】

总结------》【Mysql】

总结------》【Redis】

总结------》【Kafka】

总结------》【Spring】

总结------》【SpringBoot】

总结------》【MyBatis、MyBatis-Plus】

总结------》【Linux】

总结------》【MongoDB】

总结------》【Elasticsearch】

Java------》线程间是如何通信的

线程之间的通信有两种方式:共享内存消息传递

一、共享内存

在共享内存的并发模型里,线程之间共享程序的公共状态,线程之间通过写-读内存中的公共状态来隐式进行通信。

典型的共享内存通信方式,就是通过共享对象进行通信。

例如线程A与线程B之间如果要通信的话,那么就必须经历下面两个步骤:

  1. 线程A:把本地内存A更新过的共享变量刷新到主内存中去。
  2. 线程B:到主内存中去读取线程A之前更新过的共享变量

二、消息传递

在消息传递的并发模型里,线程之间没有公共状态,线程之间必须通过明确的发送消息来显式进行通信。

在Java中典型的消息传递方式:

  • wait()和notify()方法
  • wait(long timeout)和notify()方法
  • join()方法
  • Lock和Condition接口
  • BlockingQueue阻塞队列

1、wait()和notify()方法

wait()方法使线程进入等待状态,直到其他线程调用notify()或notifyAll()方法将其唤醒。notify()方法唤醒一个等待中的线程,notifyAll()方法唤醒所有等待中的线程。

2、wait(long timeout)和notify()方法

wait(long timeout)方法使线程进入等待状态,直到其他线程调用notify()方法将其唤醒,或者等待时间超过指定的timeout时间。notify()方法唤醒一个等待中的线程。

3、join()方法

join()方法使一个线程等待另一个线程执行完毕。当一个线程调用另一个线程的join()方法时,当前线程将被阻塞,直到另一个线程执行完毕。

4、Lock和Condition接口

Lock接口提供了比synchronized关键字更灵活的锁机制,Condition接口提供了更灵活的等待/通知机制。

通过Lock接口的lock()方法获取锁,unlock()方法释放锁。

通过Condition接口的await()方法使线程等待,signal()方法唤醒一个等待中的线程,signalAll()方法唤醒所有等待中的线程。

5、BlockingQueue阻塞队列

BlockingQueue是一个支持阻塞操作的队列。

当队列为空时,获取元素的线程将被阻塞,直到队列中有可用元素;

当队列满时,插入元素的线程将被阻塞,直到队列有空闲位置。

相关推荐
挺菜的12 分钟前
【算法刷题记录(简单题)003】统计大写字母个数(java代码实现)
java·数据结构·算法
掘金-我是哪吒1 小时前
分布式微服务系统架构第156集:JavaPlus技术文档平台日更-Java线程池使用指南
java·分布式·微服务·云原生·架构
亲爱的非洲野猪1 小时前
Kafka消息积压的多维度解决方案:超越简单扩容的完整策略
java·分布式·中间件·kafka
wfsm1 小时前
spring事件使用
java·后端·spring
微风粼粼2 小时前
程序员在线接单
java·jvm·后端·python·eclipse·tomcat·dubbo
缘来是庄2 小时前
设计模式之中介者模式
java·设计模式·中介者模式
rebel2 小时前
若依框架整合 CXF 实现 WebService 改造流程(后端)
java·后端
代码的余温3 小时前
5种高效解决Maven依赖冲突的方法
java·maven
慕y2743 小时前
Java学习第十六部分——JUnit框架
java·开发语言·学习
paishishaba4 小时前
Maven
java·maven