当前位置: 首页 > news >正文

线程间和进程间是如何进行通信

进程是由线程组成的,进程所拥有的功能线程全部具有,线程所拥有的功能进程不一定有,所有线程的通信方式,进程不一定有。

线程之间的通信主要有两种:共享内存信息传递  (端口,方法调用等等)

进程之间的通信方式有:

  1. 管道(Pipe)‌:包括匿名管道和命名管道。匿名管道主要用于父子进程间的单向通信,而命名管道允许无亲缘关系的进程间通信‌12。
  2. 信号量(Semaphore)‌:用于控制多个进程对共享资源的访问,防止资源冲突‌12。
  3. 消息队列(Message Queue)‌:进程可以通过消息队列异步地发送和接收消息,提供消息排序和优先级管理‌12。
  4. 共享内存(Shared Memory)‌:多个进程可以直接访问同一块内存区域,实现高效的数据交换,但需要额外的同步机制来避免竞争条件‌。
  5. 信号(Signal)‌:一种软中断机制,用于通知进程某个事件的发生,尽管用于进程通信较少,但在进程控制和异常处理方面非常有用‌。

Java中线程的通信

从抽象的角度来看,

JMM定义了线程和主内存之间的抽象关系:线程之间的共享变量存储在主内存(Main Memory)中,每个线程都有一个私有的本地内存(Local Memory),本地内存中存储了该线程以读/写共享变量的副本。本地内存是JMM的一个抽象概念,并不真实存在。它涵盖了缓存、写缓冲区、寄存器以及其他的硬件和编译器优。

如图所示,本地内存A和本地内存B由主内存中共享变量x的副本。假设初始时,这3个内存中的x值都为0。线程A在执行时,把更新后的x值(假设值为1)临时存放在自己的本地内存A中。当线程A和线程B需要通信时,线程A首先会把自己本地内存中修改后的x值刷新到主内存中,此时主内存中的x值变为了1。随后,线程B到主内存中去读取线程A更新后的x值,此时线程B的本地内存的x值也变为了1。

从整体来看,这两个步骤实质上是线程A在向线程B发送消息,而且这个通信过程必须要经过主内存。JMM通过控制主内存与每个线程的本地内存之间的交互,来为Java程序员提供内存可见性保证。

相关文章:

  • 复变函数 $w = z^2$ 的映射图像演示
  • 端到端的导航技术NeuPAN论文讲解
  • 《AI Agent项目开发实战》DeepSeek R1模型蒸馏入门实战
  • 达梦数据库 Windows 系统安装教程
  • HTML 中 class 属性介绍、用法
  • 【学习笔记】On the Biology of a Large Language Model
  • ffmpeg 的视频格式转换 c# win10
  • 使用免费wordpress成品网站模板需要注意点什么
  • 【SpringBoot】| 接口架构风格—RESTful
  • opencv调用模型
  • 交换机、路由器配置
  • Oracle expdp过滤部分表数据
  • Python编程基础(三) | 操作列表
  • ESP32与STM32
  • 【MIMO稳定裕度】基于数据驱动的多输入多输出系统稳定裕度分析
  • ps曝光度调整
  • 408考研逐题详解:2009年第27题
  • 【笔记】Windows 下载并安装 ChromeDriver
  • SpringBoot(六)--- AOP、ThreadLocal
  • Hadoop学习笔记
  • win系统做网站/建站网站关键词优化
  • 教学网站在线自测功能怎么做/360关键词排名推广
  • 网站制作英文版网站/东莞市优速网络科技有限公司
  • 上海网站建设专业公司哪家好/西点培训学校
  • 网站进不去怎么解决/网站推广代理
  • 提升学历图片/武汉seo优化分析