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

理解几种常见的进程间通信方式什么是进程间通信广义上讲,进程间通信(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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 云之遥全攻略 上「建议收藏」

    云之遥全攻略 上「建议收藏」转自dakkifox作者的和讯博客,很详尽很有用的一篇攻略。原贴地址:http://dakkifox.blog.hexun.com/45908818_d.html我是傻瓜分割线所谓傻瓜版,就是你照

    2022年8月2日
    5
  • mysql中phpmyadmin安装教程_安装phpMyAdmin图文教程[通俗易懂]

    mysql中phpmyadmin安装教程_安装phpMyAdmin图文教程[通俗易懂]phpmyadmin的安装配置已经是老生常谈的话题了,网络上到处都可以找到相关的配置教程。但是,那些大多都是手动配置的,稍不留神,容易出错。因此站长今天在这里介绍的是,被很多phpmyadmin用户所忽略的phpmyadmin自带的安装程序,下面我们就开始一步一步来安装phpmyadmin。1、首先下载phpmyadmin3.4.11,这是目前最稳定无bug的版本,点击下载2、在你的web根目录新…

    2022年6月1日
    27
  • JAVA–Map集合详解

    JAVA–Map集合详解特点:该集合存储键(key)值(value)对,一对一对往里存,而且要保证键(key)的唯一性。Map集合和Set集合很像,其实Set集合底层就是使用了Map集合。什么时候使用Map集合:当数据之间存在映射关系时,优先考虑Map集合。Map集合常用共有方法1.添加Vput(Kkey,Vvalue):将指定的值与此映射中的指定键关联…

    2022年5月27日
    38
  • 通俗易懂的Mybatis工作原理[通俗易懂]

    作为半自动的ORM框架,Mybatis被越来越多的企业接受。搞清楚它的工作原理以及底层实现,对于开发者可事半功倍。很多文章都是使用大批量的源码流程去分析原理。对于有源码阅读功底的开发者,也许还能招架住,但还是不直观。我以前的很多文章都是这么做的,后来有朋友私信建议说,这些文章类似于个人笔记,只能自己阅读,不利于分享,所以,本文将尝试采用通俗易懂的白话文带领大家认识一下Mybatis的工作原理。(PS:大家可以设想,如果自己在开发Mybatis,该如何设计好Mybatis的功能呢?)一...

    2022年4月17日
    43
  • JAVA基础—类—11.29

    JAVA基础—类—11.29

    2021年10月6日
    33
  • bat全屏运行_cmd指令打开全屏

    bat全屏运行_cmd指令打开全屏新建1.vbsSetobjShell=CreateObject(“Wscript.Shell”)objShell.SendKeys”{F11}”Setxxx用于指示一个未初始化的对象值,或者把对象变量从对象分离用于释放系统资源。新建test.bat@echooffstarthttps://blog.csdn.net/qq_44275213choice/t1/dy/n>nulstart%cd%\1.vbs…

    2022年9月2日
    6

发表回复

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

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