理解几种常见的进程间通信方式

理解几种常见的进程间通信方式什么是进程间通信广义上讲,进程间通信(Inter-ProcessCommunication,IPC)是指运行在不同进程(不论是否在同一台机器)中的若干线程间的数据交换。从上面的定义可以得出两点:参与通信的进程即可以运行在同一台机器上,也可以运行在各自的设备环境中(RemoteProcedureCallProtocol,RPC)。如果进程是跨机器运行的,则通常是由网络连接在一起。实现方

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

什么是进程间通信

广义上讲,进程间通信(Inter-Process Communication, IPC)是指运行在不同进程(不论是否在同一台机器)中的若干线程间的数据交换。

从上面的定义可以得出两点:

  • 参与通信的进程即可以运行在同一台机器上,也可以运行在各自的设备环境中(Remote Procedure Call Protocol, RPC)。如果进程是跨机器运行的,则通常是由网络连接在一起。
  • 实现方式可以有多种多样。原则上,任何跨进程的数据交换都可以称为进程间通信。

常见的几种进程间通信方式

共享内存(Shared Memory)

共享内存是一种常见的进程间通信机制。由于两个进程可以直接访问同一块儿内存区域,减少了数据的复制操作,因而在速度上的优势比较明显。

一般情况下,实现内存共享的步骤如下:

  1. 创建内存共享区

    内存共享区存在于内核中

  2. 映射内存共享区

    需要将内存共享区映射到进程的空间中才可以进一步操作

  3. 访问内存共享区

  4. 进程间通信

    由于内存共享本身并没有提供同步机制,所遇参与通信的各个进程需要自己协商处理。

  5. 撤销内存映射区

  6. 删除内存共享区

管道(Pipe)

管道这个词很形象地描述了通信双方的行为:

  • 分别处于管道的两方,进行数据传输通信。
  • 管道是单向的,如果一个进程既要读又要写,需要建立两根管道。类似于水管的特性。
  • 管道的两端分别为”读取端”(read end)和”写入端”(write end)。

管道的局限性

  • 生命周期是随进程结束而完结
  • 只能用于具有亲缘关系的进程通信
  • 管道是匿名的,没有名字

为了克服管道上述的局限性,可以使用命名管道(Named Pipe)。它具有管道所有的功能,并且没有管道的上述局限。

套接字(Socket)

其实网络通信中所使用的API与跨进程使用的是完全一样的。

两种角色:服务器与客户端。
每种角色的大致流程如下:

服务器:

  • Create socket – socket()
  • Bind sockaddr – bind()
  • Listen – listen()
  • Wait & Accept
    • 一般在一个循环里边监听是否有新的连接 – accept();然后可以读写了
    • 读 – recv()
    • 写 – send()
    • 关闭连接与客户端的连接 – close()
  • 释放socket close()

客户端:

  • Create socket – socket()
  • Bind sockaddr – bind()
  • 连接服务器 – accept();然后可以读写了
  • 读 recv()
  • 写 send()
  • 关闭连接 close()

注意,如果服务器与客户端在同一台主机上,则是跨进程通信。如果在不同的主机上,则变成了网络通信。

消息队列(Message Queue)

信号(Signal)

信号量(Semophore)

参考

  1. Java进程通信
  2. Linux进程间通信方式–本地socket
  3. 进程间通信——socket
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/184029.html原文链接:https://javaforall.net

(0)
上一篇 2022年10月9日 下午7:46
下一篇 2022年10月9日 下午8:00


相关推荐

  • js将时间戳转化为年月日时分秒_时间戳转换成日期

    js将时间戳转化为年月日时分秒_时间戳转换成日期/***时间戳转化为年月日时分秒*@param{*}number传入时间戳*@param{*}format返回格式,支持自定义,但参数必须与formateArr里保持一致*@returns*/exportconstformatTime=(number,format)=>{letformateArr=[‘Y’,’M’…

    2025年5月28日
    8
  • DeepSeek-R1大模型本地部署,保姆级教程(附教程)

    DeepSeek-R1大模型本地部署,保姆级教程(附教程)

    2026年3月16日
    4
  • Python迭代器实现

    Python迭代器实现文章目录欢迎访问我的个人博客引言 iter 和 next 实现可迭代的斐波那契数列类参考欢迎访问我的个人博客博客引言在 Python 编程中 我们经常使用 for in 语句对容器进行迭代 容器类 比如列表 元组等 之所以可以被 for in 语句迭代 是因为这些容器类实现了 iter 魔术方法 这个方法返回一个迭代器对象 迭代器对象实现了 next 魔术方法 这个方法可以移动迭代器和获取迭代器指向的值 如果我们想要实现支持迭代的对象 只需要实现 iter 方法以及 iter 返

    2025年12月11日
    6
  • 孙鑫老师 java从入门到精通 视频教程 批量下载

    孙鑫老师 java从入门到精通 视频教程 批量下载本视频教程是孙鑫老师亲自开发录制的,内容涵盖了java技术从入门到精通整个过程。对于java爱好者是一套不可多得的教材!相信下载此教程的同志都是未来的电脑高手,对于批量下载的方法我在这时就不一一说了,相信兄弟们都能找到这种简单规律。这里以第三课批量下载为例简单说一下:(记得将通配符长度设为1哦)第一课Java的一些基本概念http://www.ibook8.com/te

    2022年5月17日
    45
  • Android Studio实现简单的记事本「建议收藏」

    Android Studio实现简单的记事本「建议收藏」手把手教你搭建一个记事本项目,简单又好用,经典之作。

    2025年6月30日
    4
  • 细粒度图像分类(FGVC)—综述[通俗易懂]

    细粒度图像分类(FGVC)—综述[通俗易懂]一、概述什么是细粒度图像分类细粒度图像分类问题是对大类下的子类进行识别。细粒度图像分析任务相对通用图像(General/GenericImages)任务的区别和难点在于其图像所属类别的粒度更为精细。以图1为例,通用图像分类其任务诉求是将“袋鼠”和“狗”这两个物体大类(蓝色框和红色框中物体)分开,可见无论从样貌、形态等方面,二者还是很容易被区分的;而细粒度图像的分类任务则要求对“狗”该类类别……

    2025年5月26日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号