1.理解层面

为什么要进程间通信?

• 数据传输:⼀个进程需要将它的数据发送给另⼀个进程

• 资源共享:多个进程之间共享同样的资源。

• 通知事件:⼀个进程需要向另⼀个或⼀组进程发送消息,通知它(它们)发⽣了某种事件(如进

程终止时要通知父进程)。

• 进程控制:有些进程希望完全控制另⼀个进程的执行(如Debug进程),此时控制进程希望能够

拦截另⼀个进程的所有陷⼊和异常,并能够及时知道它的状态改变。

怎么通信?

    进程间通信的本质:是先让不同的进程,先看同一份资源["内存"]。(然后才有通信的的条件)

                                                                        任何一个进程提供?---不是。需要由OS提供

OS提供---系统调用---OS的接口(设计统一的通信接口)

什么是通信?                          

进程问通信(IPC,Inter-Process Communication)是指运行在同一台计算机成不同计算机上的多个进程之间进行数据交换和通信的技术,由于每个进程都有自己的地址空间,它们无法直接访问彼此的数据,因此需要通过特定的机制来实现通信,IPC是操作系统和多进程编程中的一个重要概念,广泛应用于分布式系统、多任务操作系统以及各种应用程序之间。

标准

2.环境问题

Ubuntu20.04+C+++vscode

如果是轻量云服务器,云服务器实例,重装系统/更多->重新安装

vscode---编辑器---支持插件化的配置

vscode配置:

    1.Remote - SSH

    2.调试--GDB debug

    3.fitten code

小电脑ssh root@自己ip地址

然后输入密码就成功连接了

我们先来简单建立三个文件

code.cpp

root@iZ5waahoxw3q2bZ:~/linux-learning/linux/26-6-2# cat code.cpp
#include<iostream>

int main()
{
    return 0;
}
Makefile

root@iZ5waahoxw3q2bZ:~/linux-learning/linux/26-6-2# cat Makefile
code.exe:test.c
        gcc -o $@ $^
.PHONY:clean
clean:
        rm -f code.exe
test.c

root@iZ5waahoxw3q2bZ:~/linux-learning/linux/26-6-2# cat test.c
#include<stdio.h>

int main()
{
    printf("hello world!\n");
    printf("hello world!\n");
    printf("hello world!\n");
    printf("hello world!\n");
    printf("hello world!\n");
    printf("hello world!\n");
    printf("hello world!\n");
    printf("hello world!\n");
    return 0;
}
root@iZ5waahoxw3q2bZ:~/linux-learning/linux/26-6-2# make
gcc -o code.exe test.c

root@iZ5waahoxw3q2bZ:~/linux-learning/linux/26-6-2# ./code.exe
hello world!
hello world!
hello world!
hello world!
hello world!
hello world!
hello world!
hello world!

3.具体通信方式的(原理+代码)

    1.基于文件的,管道通信

    2.System V -本机通信

匿名管道

1.背景

            文件上

    基于已有的技术,直接进行通信

什么是管道

• 管道是Unix中最古⽼的进程间通信的形式。

• 我们把从⼀个进程连接到另⼀个进程的⼀个数据流称为⼀个“管道

匿名管道,通常用来做父子通信!

我们对应的子进程,它要把这个父进程的struct_file文件描述符表也要给子进程拷一份。
那么创建子进程时,需不需要把曾经父进程打开的这一堆文件也给子进程拷一份呢?

不需要。左边属于进程右边属于文件管理,双方互不干扰。

父子进程文件描述表相同指向同一个文件管理,从而实现通信。可以说是浅拷贝

让父子看到同一个资源叫做管道

真的管道文件是内存级的,不需要刷新到磁盘上,和磁盘没关系

2.原理

内存级

这个管道是被OS单独设计的---配上单独的系统调用

 /* On all other architectures */

       int pipe(int pipefd[2]);

       不要文件路径,内存级的,没有文件名

       匿名管道!!!


 

我们是怎么保证,两个进程,打开的是同一个管道文件呢?

    子进程继承父进程的文件描述表

浅拷贝是发生在struct file的

管道也是文件,属于文件系统!

感谢你的观看,期待我们下次再见!

Logo

openEuler 是由开放原子开源基金会孵化的全场景开源操作系统项目,面向数字基础设施四大核心场景(服务器、云计算、边缘计算、嵌入式),全面支持 ARM、x86、RISC-V、loongArch、PowerPC、SW-64 等多样性计算架构

更多推荐