16.进程间的通信:管道

1.popen(), pclose()
2.pipe()
    2.1 普通 pipe
    2.2 父子进程 pipe
    2.3 不同进程 pipe
    2.4 用管道当作 标准输入,标准输出
    2.5 命名管道

1.什么是管道
16.进程间的通信:管道_第1张图片
16.进程间的通信:管道_第2张图片
16.进程间的通信:管道_第3张图片

2.进程管道
16.进程间的通信:管道_第4张图片
16.进程间的通信:管道_第5张图片
16.进程间的通信:管道_第6张图片

3.将输出送往 popen
16.进程间的通信:管道_第7张图片
16.进程间的通信:管道_第8张图片
16.进程间的通信:管道_第9张图片
16.进程间的通信:管道_第10张图片
16.进程间的通信:管道_第11张图片
16.进程间的通信:管道_第12张图片
16.进程间的通信:管道_第13张图片
这里写图片描述

4.pipe 调用
16.进程间的通信:管道_第14张图片
16.进程间的通信:管道_第15张图片
16.进程间的通信:管道_第16张图片
16.进程间的通信:管道_第17张图片
16.进程间的通信:管道_第18张图片
16.进程间的通信:管道_第19张图片

#include 
#include 
#include 
#include 

int main()
{
    int data_processed;
    int file_pipes[2];
    const char some_data[] = "123";
    char buffer[BUFSIZ + 1];
    pid_t fork_result;

    memset(buffer, '\0', sizeof(buffer));

    if (pipe(file_pipes) == 0) {
        fork_result = fork();
        if (fork_result == -1) {
            fprintf(stderr, "Fork failure");
            exit(EXIT_FAILURE);
        }

// We've made sure the fork worked, so if fork_result equals zero, we're in the child process.

        if (fork_result == 0) {
            data_processed = read(file_pipes[0], buffer, BUFSIZ);
            printf("Read %d bytes: %s\n", data_processed, buffer);
            exit(EXIT_SUCCESS);
        }

// Otherwise, we must be the parent process.

        else {
            data_processed = write(file_pipes[1], some_data,
                                   strlen(some_data));
            printf("Wrote %d bytes\n", data_processed);
        }
    }
    exit(EXIT_SUCCESS);
}

5.父进程和子进程
16.进程间的通信:管道_第20张图片
16.进程间的通信:管道_第21张图片
16.进程间的通信:管道_第22张图片
16.进程间的通信:管道_第23张图片
16.进程间的通信:管道_第24张图片
16.进程间的通信:管道_第25张图片
16.进程间的通信:管道_第26张图片
16.进程间的通信:管道_第27张图片
16.进程间的通信:管道_第28张图片
16.进程间的通信:管道_第29张图片
16.进程间的通信:管道_第30张图片


  1. 命名管道:FIFO
    16.进程间的通信:管道_第31张图片
    16.进程间的通信:管道_第32张图片
    16.进程间的通信:管道_第33张图片
    16.进程间的通信:管道_第34张图片
    16.进程间的通信:管道_第35张图片
    16.进程间的通信:管道_第36张图片
    16.进程间的通信:管道_第37张图片
    16.进程间的通信:管道_第38张图片
    16.进程间的通信:管道_第39张图片
    16.进程间的通信:管道_第40张图片
    16.进程间的通信:管道_第41张图片
    16.进程间的通信:管道_第42张图片
    16.进程间的通信:管道_第43张图片
    16.进程间的通信:管道_第44张图片
    16.进程间的通信:管道_第45张图片
    16.进程间的通信:管道_第46张图片
    16.进程间的通信:管道_第47张图片

16.进程间的通信:管道_第48张图片
16.进程间的通信:管道_第49张图片
16.进程间的通信:管道_第50张图片
16.进程间的通信:管道_第51张图片
16.进程间的通信:管道_第52张图片
16.进程间的通信:管道_第53张图片
16.进程间的通信:管道_第54张图片
16.进程间的通信:管道_第55张图片

把管道做标准输入和标准输出:
好处是 可以调用标准程序,即那些不需要以文件描述符作为参数的程序
先关闭标准输入,然后用 dup() 函数
管道有长度限制: PIPE_BUF
一个管道,多个写进程的话,必须保持写请求是发往一个阻塞的 FIFO,并且每次写请求的数据长度小于等于 PIPE_BUF 字节,系统就能保证写数据不会交错在一起。

16.进程间的通信:管道_第56张图片

你可能感兴趣的:(Linux,书籍)