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是一个支持阻塞操作的队列。

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

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

相关推荐
水痕0114 分钟前
gin结合minio来做文件存储
java·eureka·gin
寒士obj23 分钟前
Spring事物
java·spring
柯南二号1 小时前
【Java后端】Spring Boot 集成 MyBatis-Plus 全攻略
java·spring boot·mybatis
桦说编程9 小时前
Java 中如何创建不可变类型
java·后端·函数式编程
lifallen9 小时前
Java Stream sort算子实现:SortedOps
java·开发语言
IT毕设实战小研9 小时前
基于Spring Boot 4s店车辆管理系统 租车管理系统 停车位管理系统 智慧车辆管理系统
java·开发语言·spring boot·后端·spring·毕业设计·课程设计
没有bug.的程序员9 小时前
JVM 总览与运行原理:深入Java虚拟机的核心引擎
java·jvm·python·虚拟机
甄超锋10 小时前
Java ArrayList的介绍及用法
java·windows·spring boot·python·spring·spring cloud·tomcat
cui__OaO10 小时前
Linux软件编程--线程
linux·开发语言·线程·互斥锁·死锁·信号量·嵌入式学习
阿华的代码王国10 小时前
【Android】RecyclerView复用CheckBox的异常状态
android·xml·java·前端·后端