【项目 进程5】 2.10 进程间通信简介 2.11匿名管道概述 2.12父子进程通过匿名管道通信

news2025/1/13 13:45:13

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

    • 2.10 进程间通信简介(IPC iner process communication)
      • Linux进程间通信的方式(记)
    • 2.11匿名管道概述
      • 匿名管道
      • 管道的特点(记)
      • 为什么可以使用管道进行进程间通信
      • 管道的数据结构
      • 匿名管道的使用
    • 2.12父子进程通过匿名管道通信
      • 创建匿名管道
      • 查看管道缓冲大小函数


2.10 进程间通信简介(IPC iner process communication)

在这里插入图片描述
简称:
GUI:图形用户 接口 graphic user interface
IDE:集成开发环境
API:应用程序接口

同步和异步
看医生一个一个去,异步是好几个人一起。
异步容易产生安全问题。

Linux进程间通信的方式(记)

还有一种:内存映射
在这里插入图片描述在讨论Unix进程和System V进程之间的区别之前,有必要先了解一下这两个术语的含义。

Unix 是一种广泛使用的操作系统,它有很多不同的变体或分支,例如Linux,BSD,Solaris等。这些变体基于原始的Unix系统,并添加或修改了一些特性。Unix进程是在这些系统中运行的程序实例。

System V(读作"System Five")是UNIX的一个主要版本,由AT&T贝尔实验室在20世纪80年代开发。这个版本的UNIX对UNIX的历史发展产生了深远影响,并为许多现代UNIX和类UNIX系统,包括Linux,设置了很多标准。

所以,我们在讨论Unix进程和System V进程之间的区别时,实际上是在讨论不同Unix变体或版本之间进程管理的差异。

有些进程管理的特性在System V中是独有的,比如它引入了更强大的进程间通信(IPC)机制,包括信号量,消息队列和共享内存。另一方面,许多现代的Unix系统(包括Linux和BSD)也实现了自己的IPC机制和其他进程管理特性,有些可能与System V的实现有所不同。

同时,Unix进程和System V进程的行为也可能受到具体操作系统内核的调度策略、资源管理策略等因素的影响,这些因素都可能导致在不同系统或版本上的进程表现出不同的行为。

总的来说,尽管存在这些差异,但是Unix进程和System V进程的基本概念和设计原则是相同的。这是因为所有的Unix和类Unix系统都继承了原始Unix的设计理念,包括进程的概念,进程的生命周期管理,以及进程间的通信等。

2.11匿名管道概述

匿名管道

在这里插入图片描述
每个进程的内核有文件描述符表,其中0 1 2分别代表标准输入、标准输出、标准错误。标准输入输出的文件就是输出,是从内存角度来看的。输出就是从内存输出到文件(写)。管道即改变了两个进程的输出和输入对象

解释:

  • ls获取一个目录中文件的列表,“|”创建管道服务,wc统计文件数目。
  • ls是一个列出目录内容的命令。当不带任何参数运行时,ls会列出当前目录下的所有文件和目录。
  • |是一个管道操作符,它可以把一个命令的输出作为另一个命令的输入。ls | wc -l就是把ls的输出(即目录的内容列表)作为wc -l的输入。
  • wc是"word count"的缩写,它是一个统计文本文件中字节数、单词数和行数的命令。当带上-l参数时,wc -l只统计输入中的行数。
  • 因此,ls | wc -l这个命令组合的作用是:列出当前目录下的所有文件和目录,并计算它们的数量。
  • wc 是 Linux 和 Unix 系统中的一个命令,它代表 “word count”,即"字数统计"。这个命令可以用来计算文本文件中的字节数、单词数和行数。

关于wc命令:
wc 命令的基本使用格式是 wc [选项] 文件名。你可以指定一个或多个文件名,wc 会为每个文件单独计算这些统计量,并在最后一行给出所有文件的总计。

wc 命令的主要选项包括:

  • -l:仅计算行数
  • -w:仅计算单词数
  • -c:仅计算字节数
  • -m:仅计算字符数

例如,wc -l file.txt 就会计算出 file.txt 文件中的行数。如果你不指定任何选项,wc 会同时计算行数、单词数和字节数,并按照这个顺序输出结果。

请注意,wc 命令的 “字” 和 “单词” 的定义可能与你的直觉有所不同。在 wc 的上下文中,一个 “字” 是指一个字节,而一个 “单词” 是指由空白字符(如空格、制表符或换行符)分隔的字符串。因此,如果你的文件中包含非ASCII字符(如UTF-8编码的中文字符),wc -cwc -m 的结果可能会不同,因为一个非ASCII字符可能由多个字节组成。

管道的特点(记)

在这里插入图片描述
在这里插入图片描述
管道两端对应文件描述符
从现实应用角度理解单工、双工、半双工:
单工-遥控器发送数据给电视(单向发送消息)
双工-打电话
半双工-同一时刻,数据只能往一个方向发送,比如对讲机(双向发送 但不同时)

为什么可以使用管道进行进程间通信

在这里插入图片描述
fork()创建子进程,父子进程共享文件描述符fd,文件描述符表处于内核中,上图中5指向管道读端,6指向管道写端。

管道的数据结构

在这里插入图片描述
环形队列(循环队列)逻辑上,可覆盖被读走数据的内存写入数据
展开成一个长条,可以看成读指针总是跟在写指针屁股后面

匿名管道的使用

在这里插入图片描述

2.12父子进程通过匿名管道通信

创建匿名管道

管道默认是阻塞的:如果管道中没有数据,read阻塞,如果管道满了,write阻塞

/*
    #include <unistd.h>
    int pipe(int pipefd[2]);
        功能:创建一个匿名管道,用来进程间通信。
        参数:int pipefd[2] 这个数组是一个传出参数。
            pipefd[0] 对应的是管道的读端
            pipefd[1] 对应的是管道的写端
        返回值:
            成功 0
            失败 -1

    管道默认是阻塞的:如果管道中没有数据,read阻塞,如果管道满了,write阻塞

    注意:匿名管道只能用于具有关系的进程之间的通信(父子进程,兄弟进程)
*/

// 子进程发送数据给父进程,父进程读取到数据输出
#include <unistd.h>
#include <sys/types.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

int main() {

    // 重点:在fork之前创建管道
    int pipefd[2];//传出参数
    int ret = pipe(pipefd);
    if(ret == -1) {
        perror("pipe");
        exit(0);
    }

    // 创建子进程
    pid_t pid = fork();
    if(pid > 0) {
        // 父进程:可实现先读再写
        printf("i am parent process, pid : %d\n", getpid());

        // 关闭写端
        //close(pipefd[1]);
        
        // 从管道的读取端读取数据
        char buf[1024] = {0};
        while(1) {
            int len = read(pipefd[0], buf, sizeof(buf));
            printf("parent recv : %s, pid : %d\n", buf, getpid());
            
            //向管道中写入数据
            char * str = "hello,i am parent";
            write(pipefd[1], str, strlen(str));
            sleep(1); 
        }

    } else if(pid == 0){
        // 子进程:可实现先写再读
        printf("i am child process, pid : %d\n", getpid());
        // 关闭读端
        //close(pipefd[0]);
        char buf[1024] = {0};
        while(1) {//while循环实现不断的发送数据
            // 向管道中写入数据
            char * str = "hello,i am child";
            write(pipefd[1], str, strlen(str));
            sleep(1);

            //父子进程交替接收数据
            int len = read(pipefd[0], buf, sizeof(buf));
            printf("child recv : %s, pid : %d\n", buf, getpid());
            bzero(buf, 1024);
        }
        
    }
    return 0;
}
//一个管道如果用作双向的数据传递,就容易出现父进程发送父进程接收的问题,
//所以一般父子进程的输入和输出的规定好的,不再交换。可以在一开始就关掉一个fd


查看管道缓冲大小函数

在这里插入图片描述
用ulimit -a命令查看 上图表示缓冲区有8块,每一块是512字节,所以一共是8*512 = 4K大小

#include <unistd.h>
#include <sys/types.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

int main() {

    int pipefd[2];//传出参数

    int ret = pipe(pipefd);

    // 获取管道的大小:4KB 4096 可修改
    //第二个参数为宏值,表示获取管道的大小
    long size = fpathconf(pipefd[0], _PC_PIPE_BUF);

    printf("pipe size : %ld\n", size);

    return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/780799.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

第一天 运维高级 MySQL备份与还原

1.创建student和score表 CREATE TABLE student ( id INT(10) NOT NULL UNIQUE PRIMARY KEY , name VARCHAR(20) NOT NULL , sex VARCHAR(4) , birth YEAR, department VARCHAR(20) , address VARCHAR(50) );CREATE TABLE score ( id INT(10) NOT NULL UNIQUE PRIMARY KEY AUTO…

a-tree 实现父级节点禁用,通过子级节点勾选状态控制

a-tree 组件实现折叠选择&#xff1b;使其父级节点禁用&#xff0c;通过子级节点的勾选状态来控制是否勾选&#xff1b;如果子级节点勾选任一个&#xff0c;父级节点就勾选中&#xff0c;如果子级节点全部不勾选则父节点不勾选&#xff0c;否则勾选 &#xff0c;效果如下&#…

Vue中TodoList案例_总结

完整项目&#xff1a; App.vue <template><div id"root"><div class"todo-container"><div class"todo-wrap"><MyHeader :addTodo"addTodo"/><MyList :todos"todos" :checkTodo"che…

LeetCode226. 翻转二叉树

226. 翻转二叉树 文章目录 [226. 翻转二叉树](https://leetcode.cn/problems/invert-binary-tree/)一、题目二、题解方法一&#xff1a;层序遍历迭代方法二&#xff1a;前序遍历(递归)方法三&#xff1a;中序遍历&#xff08;递归&#xff09;方法四&#xff1a;后序遍历&#…

c++ visual studio opencv配置

项目属性表配置方式&#xff1a; 1、新建项目后&#xff0c;在属性管理器中&#xff0c;创建一个项目属性表&#xff1a; 注&#xff1a;根据需求创建。 2、双击项目属性表 依次修改包含目录、库目录、附加包含目录、附加依赖项。 2.1【包含目录】中加入 OpenCV 的 include …

为harbor仓库添加https,新增DigiCert 免费版SSL证书

完成效果&#xff1a; 前言&#xff1a;在本地搭建好docker的镜像仓库harbor后&#xff0c;当我们登录docker login时&#xff0c;会提示证书问题x509: cannot validate certificate 登录本地报错X509 无法登录仓库也无法上传和拉取镜像&#xff0c;虽然有本机的解决方法&…

android studio 新建项目没有R文件

android studio 新建项目没有R文件&#xff0c;处理步骤 1&#xff0c;找一个能打开的项目替换根目录下的settings.gradle 2,改app 目录下的build.gradle文件 3&#xff0c;改gradle版本 4&#xff0c;改AndroidManifest.xml 5&#xff0c;改theme 改为&#xff0c;ok.

gtest测试用例注册及自动化调度机制源代码流程分析

gtest的入门参见&#xff1a; 玩转Google开源C单元测试框架Google Test系列(gtest) gtest源码分析流程参见&#xff1a; gtest流程解析 测试用例注册流程分析要点&#xff1a;TEST_F宏替换、C静态成员的动态初始化。 自动化调度流程分析要点&#xff1a;UnitTest、UnitTestIm…

CRM系统的排名?都有哪些特点?

在当今商业世界中&#xff0c;CRM客户管理系统是每一家企业所必不可少的工具。它们能够帮助企业管理客户信息&#xff0c;跟进销售机会以及提高客户体验。众多的CRM中&#xff0c;哪个CRM性价比高&#xff0c;企业该如何选择&#xff1f; 在比较CRM软件时&#xff0c;除基本功…

90道渗透测试面试题(附答案)

2023年已经快过去一半了&#xff0c;不知道小伙伴们有没有找到自己心仪的工作呀。最近后台收到不少小伙伴说要我整理一些渗透测试的面试题&#xff0c;今天它来了&#xff01;觉得对你有帮助的话记得点个赞再走哦~ 1、什么是渗透测试&#xff1f; 渗透测试是一种评估计算机系统…

HCIA练习2

目录 第一步 启动eNSP&#xff0c;搭建如图所示的拓扑结构 第二步 进行子网的划分 ​第三步 从第二步划分的16个网段中&#xff0c;选择14个网段进行使用 第四步 对路由器各个端口进行IP配置 第五步 对每个路由器的环回接口进行配置 第六步 对路由器进行静态路由配…

QT designer的安装+PyUIC 和 PyRCC

PyQt5的安装 整个环境的搭建&#xff0c;主要内容为&#xff1a;Python PyCharm PyQt5 学习pyqt5制作界面的视频推荐网址&#xff1a; https://www.bilibili.com/video/BV1YT4y1r7tK?spm_id_from333.999.0.0&vd_sourceda469f8dadbc58a00f885b3f7be5ef05 配置工具&…

java项目之文物管理系统(ssm+mysql+jsp)

风定落花生&#xff0c;歌声逐流水&#xff0c;大家好我是风歌&#xff0c;混迹在java圈的辛苦码农。今天要和大家聊的是一款基于ssm的文物管理系统。技术交流和部署相关看文章末尾&#xff01; 开发环境&#xff1a; 后端&#xff1a; 开发语言&#xff1a;Java 框架&…

Linux系统上安装 Redis 5.0 版本

文章目录 一、安装 gcc二、Redis官网下载安装包三、xftp上传安装包四、解压安装包五、编译与安装&#xff08;make&#xff09;六、后台启动七、查看rdis进程八、客户端连接 一、安装 gcc 安装gcc的主要作用是提供编译器和工具链&#xff0c;因为redis是c语言编写的&#xff0…

基于Vue+Element Plus实现表格组件

目录 前言分析实现例子效果图前言 表格对于管理类项目是很重要的,可以只管的展示和比比较数据。使用Element Plus能解决一部分问题,但是还存在一些缺点和不足。 分析 浏览器上表格数据展示空间不足。列显示太多不够直观。完全依赖官方表格组件代码过于臃肿不利于管理和优化…

mybatis 基础3

1.collection标签 查询-场景&#xff1a;一对多 2.动态查询 3.动态添加 4.动态修改 5. 批量添加 foreach标签中属性的用法 6.查询-参数为List 7.查询-参数为Map

【后端面经】前言汇总(0)

文章目录 一、机会是留给有准备的人二、课程设计第一部分:微服务架构第二部分:数据库与 MySQL第三部分:消息队列第四部分:缓存所谓缓存用得好,性能没烦恼。第五部分:NoSQL三、总结一、机会是留给有准备的人 近两年互联网行业增速放缓,ChatGPT 又引发了一波新的 AI 浪潮,…

“百模大战”打响,如何评估一个AI大模型的能力水平?

‍数据智能产业创新服务媒体 ——聚焦数智 改变商业 大型AI模型已经变得越来越常见&#xff0c;它们在许多复杂任务中展现出了强大的实力&#xff0c;引领着前沿技术的发展趋势。这些大模型既给了我们无限的可能&#xff0c;也带来了一个难题&#xff1a;在“百模大战”的大背…

【Flume 01】Flume简介、部署、组件

1 Flume简介 Flume是一个高可用、高可靠、分布式的海量日志采集、聚合和传输的系统 主要特性&#xff1a; 它有一个简单、灵活的基于流的数据流结构&#xff08;使用Event封装&#xff09;具有负载均衡机制和故障转移机制一个简单可扩展的数据模型(Source、Channel、Sink) Sou…

C# List 详解一

目录 一、概述 二、构造函数 1.List() 2.List(IEnumerable) 3.List(Int32) 三、属性 1.Capacity 2.Count 3.Item[Int32] 四、方法 1.Add(T) 2.AddRange(IEnumerable) 3.AsReadOnly() 4.BinarySearch(T) C# List 详解一 1.Add…