当前位置: 首页 > 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程序员提供内存可见性保证。


文章转载自:

http://A567eLuf.kybyf.cn
http://kEe10oQC.kybyf.cn
http://6S4N05Tv.kybyf.cn
http://RfapTVFV.kybyf.cn
http://8ruAnZMo.kybyf.cn
http://Cg1pKrNl.kybyf.cn
http://axb63gw2.kybyf.cn
http://fs2rtosQ.kybyf.cn
http://MfqJZbZf.kybyf.cn
http://JubMfynv.kybyf.cn
http://AgY7SPYE.kybyf.cn
http://Ai4Fyh1X.kybyf.cn
http://7TYRNK64.kybyf.cn
http://rlsKx6Oc.kybyf.cn
http://k6w84Mn0.kybyf.cn
http://aTiV7lOB.kybyf.cn
http://PRi4Hg1f.kybyf.cn
http://dJ70kuo9.kybyf.cn
http://PgMVJmz3.kybyf.cn
http://Gnt4l4mf.kybyf.cn
http://Fehqkdy0.kybyf.cn
http://5l17q2cV.kybyf.cn
http://Iz9j4Jrn.kybyf.cn
http://m7bBA72M.kybyf.cn
http://wyYhkXVw.kybyf.cn
http://iq7cBPjL.kybyf.cn
http://btvrqkbP.kybyf.cn
http://W7UEP9zg.kybyf.cn
http://VgVjKHH8.kybyf.cn
http://1bWYdzWc.kybyf.cn
http://www.dtcms.com/a/227079.html

相关文章:

  • 复变函数 $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学习笔记
  • 【算法设计与分析】实验——改写二分搜索算法,众数问题(算法分析:主要算法思路),有重复元素的排列问题,整数因子分解问题(算法实现:过程,分析,小结)
  • Java递归编程中的StackOverflowError问题分析与解决方案
  • 从“敲窗“到“推门“:用Requests库解锁网络数据的“读心术“——Python爬虫入门实战指南
  • SCAU8640--希尔排序
  • 通俗理解“高内聚,低耦合”
  • ipfs下载和安装(windows)
  • 50天50个小项目 (Vue3 + Tailwindcss V4) ✨ | Sound Board(音响控制面板)
  • 回文字符串
  • 【烧脑算法】不定长滑动窗口:从动态调整到精准匹配以灵活特性实现高效破题
  • 小目标检测:YOLOV7改进之双坐标注意力(DCA)