linux管道学习笔记

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

int main(){
    int pipe_fd[2];
    pid_t pid;
    char buf_r[100];
    char *p_wbuf;
    int r_num;

    memset(buf_r,0,sizeof(buf_r));

    //创建管道
    if(pipe(pipe_fd)<0){
        printf("pipe create error\n");
        return -1;
    }

    if((pid=fork())==0){//表示在子进程中
        printf("\n");
        //关闭管道写描述符,进行管道读操作
        close(pipe_fd[1]);
        sleep(2);
        //管道描述符中读取
        if((r_num=read(pipe_fd[0],buf_r,100))>0){
            printf("%d numbers read from the pipe is %s\n",r_num,buf_r);
        }
        close(pipe_fd[0]);
        exit(0);
    }
    else if(pid>0){//表示在父进程中,父进程写
    //关闭管道读描述符,进行管道写操作
        close(pipe_fd[0]);
        if(write(pipe_fd[1],"Hello",5)!=-1)
            printf("parent write1 success!\n");
        if(write(pipe_fd[1],"Pipe",5)!=1)
            printf("parent write2 success!\n");
        close(pipe_fd[1]);
        waitpid(pid,NULL,0);
        exit(0);
    }
}

程序讲解:

1.fork():

在Linux中创建一个新进程的唯一方法是使用fork函数,fork()执行一次但有两个返回值。

在父进程中,返回值是子进程的进程号;在子进程中,返回值为0。因此可通过返回值来判断当前进程是父进程还是子进程。

2.waitpid():

进程一旦调用了waitpid(),就立即阻塞自己,由waitpid()自动检测是否当前进程的某个子进程已经退出,如果已退出, wait就会收集这个子进程的信息,并把它彻底销毁后返回;如果没有找到这样一个子进程,waitpid()就会一直阻塞在这里。该函数的原型是pid_t waitpid(pid_t pid,int *status,int options),具体用法再另外查。

程序的运行结果:

parent write1 success!
parent write2 success!

10 numbers read from the pipe is HelloPipe


    





  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值