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

理解几种常见的进程间通信方式什么是进程间通信广义上讲,进程间通信(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年9月1日
    9
  • 我对petshop4的简单理解![通俗易懂]

    我对petshop4的简单理解![通俗易懂]petshop4充分体现了面向接口编程的思想,就是给你一个接口你别管我是怎么实现的,你只管用别说其他的。namespacePetShop.BLL{   ///   ///Abusinesscomponenttomanageproducts   ///   publicclassProduct{       //Getaninstan

    2022年8月31日
    3
  • c语言面试题目及答案_有趣的面试

    c语言面试题目及答案_有趣的面试12个C语言面试题,涉及指针、进程、运算、结构体、函数、内存,看看你能做出几个!1.gets()函数问:请找出下面代码里的问题:#include<stdio.h>intmain(void){charbuff[10];memset(buff,0,sizeof(buff));gets(buff);printf("…

    2022年8月29日
    5
  • int、bigint、smallint 和 tinyint范围「建议收藏」

    int、bigint、smallint 和 tinyint范围「建议收藏」1bytes=8bit,一个字节最多可以代表的数据长度是2的8次方11111111在计算机中也就是  -128到127  1.BIT[M]  位字段类型,M表示每个值的位数,范围从1到64,如果M被忽略,默认为1  2.TINYINT[(M)][UNSIGNED][ZEROFILL] M默认为4       从0到255的整型数据。存储大小为1

    2022年9月21日
    6
  • pytest skipif_白盒测试用例

    pytest skipif_白盒测试用例前言pytest.mark.skip可以标记无法在某些平台上运行的测试功能,或者您希望失败的测试功能Skip和xfail:处理那些不会成功的测试用例你可以对那些在某些特定平台上不能运行的测试用

    2022年7月28日
    7
  • python期货程序化开发_使用文华财经进行期货程序化真的很low,自己编程才是正途…「建议收藏」

    python期货程序化开发_使用文华财经进行期货程序化真的很low,自己编程才是正途…「建议收藏」一、目前期货程序化现状由于有免费的CTP接口,期货程序化交易目前比较普遍,很多人都尝试过在文华财经、金字塔之类的软件上回测和编写实盘策略。期货程序化交易有很多优点:程序会按照设计自动执行,不受任何其它因素干扰,设计正确的请假下不会出错。借助于程序,交易速度更快,远远超过人工下单的速度。节省人工成本,一个策略可以部署多个机器人,特别当前期货存在夜盘的情况下,耗费非常大的人力成本。可以说,从事期货交易…

    2022年10月8日
    4

发表回复

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

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