随笔 - 632  文章 - 17  评论 - 54  阅读 - 93万

Linux使用pipe管道实现父子进程之间通讯

一、概述

  管道的基本概念理解:

    1.管道本质上是一块内核缓冲区(一端将数据写入内核,另一端从内核中读取数据),内部的实现是环形队列
    2.管道有读写两端,读写两端是两个文件描述符
    3.数据的流向是从管道的写端流到管道的读端(数据的流向是单向的)
    4.数据被读走了之后,在管道中就消失了
    5.pipe只能用于有血缘关系的进程间通讯
    6.管道的读写两端是阻塞的。
    7.管道的大小默认是4k,但是会根据实际的情况做适当的调整。

二、实例代码

复制代码
//pipe用于父子进程间通讯。1.父进程创建爱你pipe,父进程调用fork函数创建子进程
//父进程关闭一端
//子进程关闭一端
//父进程和子进程分别执行read或者write操作
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/types.h>
#include <unistd.h>
#include <sys/wait.h>


int main(){
        //创建管道,fd[0]读取,fd[1]写入
        int fd[2];
        int ret = pipe(fd);
        if(ret<0){
                perror("pipe error");
                return -1;
        }
        //创建子进程
        pid_t pid= fork();

        if(pid<0){//说明创建子进程失败
                perror("create fork fail");
                return -1;
        }else if(pid>0){//说明是父进程
                //关闭读端
                close(fd[0]);
          //暂停5秒,此处的意义是让验证读取 sleep(
5);
          //向管道中写入数据,第一个参数是文件描述符id,第二个参数是写入内容,第三个参数是写入长度 write(fd[
1],"hello world",strlen("hello world"));
          //等在子进程结束,不然会出现僵尸进程 wait(NULL); }
else{//说明是子进程,此处也等价于pid==0, //关闭写端 close(fd[1]); //用于接收数据 char buf[64];
          //用于给buf初始化值 memset(buf,
0x00,sizeof(buf));
          //从管道中读取数据
int n = read(fd[0],buf,sizeof(buf)); printf("read over,n==[%d],buf==[%s]\n",n,buf); } return 0; }
复制代码

 

posted on   飘杨......  阅读(822)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
历史上的今天:
2013-11-11 android asmack调用MultiUserChat.getHostedRooms方法出现空指针的异常解决方案
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示