zoukankan      html  css  js  c++  java
  • C语言进程和进程之间通讯的方式_管道的使用

    进程和进程之间的内存是相对独立的

    进程和进程通讯原理

    进程和进程之间通讯的方式

    • 管道(使用最简单)
      • 只能用在有血缘关系的进程之中
    • 信号(开销最小)
    • 共享映射区(无血缘关系)
    • 本地套接字(最稳定,实现复杂度最高)

    管道

    管道必须用在有父子关系的进程中

    管道是一种最基本的IPC机制,作用与有血缘关系的进程之间,调用pipe系统函数,即可以创建一个管道,

    • 其本质是一个伪文件(实为内核缓存区)
    • 由两个文件描述符引用,一个表示读端,一个表示写端
    • 规定数据从管道的写入端流入管道,从读取端读出

    局限性:

    • 自己写,不能自己读
    • 数据不可以反复读
    • 单工通信
    • 血缘关系进程间可用

    pipe函数,创建并打开管道

    int pipe (int fd[2]);
    
    // 参数
    // fd[0] : 读端
    // fd[1] : 写端
    

    例:

    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>
    #include <unistd.h>
    #include <pthread.h>
    
    void sys_err(const char *str)
    {
      perror(str);
      exit(1);
    }
    
    int main(int agrc, char *argv[])
    {
      int ret;
      int fd[2];
      pid_t pid;
      
      char buf[1024];
      
      ret = pipe(fd);
      if (ret == -1){
        sys_err("pipe error");
      }
      
      pid = fork();
      if (pid>0)
      {
        close(fd[0]);  // 关闭读端
        write(fd[1], "hello pipe", strlen("hello pipe"));
        close(fd[1]);
        // 父进程
      }	else if(pid==0){
        // 子进程
        close(fd[1]);
        ret = read(fd[0], buf, size(buf));
        write(STDOUT_FILENO, buf, ret);
        close(fd[0]);
      }
      
      
      
      return 0;
    }
    
    
    

    管道的读写行为

    读管道

    1. 管道有数据,read返回实际读到的字节数
    2. 管道无数据,
      1. 无写端,read返回0
      2. 有些端,read堵塞等待

    写管道

    1. 无读端,异常终止
    2. 有读端,
      1. 管道已满,阻塞等待
      2. 管道未满,返回写出的字节个数
  • 相关阅读:
    小D课堂
    小D课堂
    小D课堂
    小D课堂
    小D课堂
    小D课堂
    小D课堂
    阶段3 3.SpringMVC·_07.SSM整合案例_09.ssm整合之Spring整合MyBatis框架配置事务
    阶段3 3.SpringMVC·_07.SSM整合案例_08.ssm整合之Spring整合MyBatis框架
    阶段3 3.SpringMVC·_07.SSM整合案例_07.ssm整合之编写MyBatis框架测试保存的方法
  • 原文地址:https://www.cnblogs.com/fandx/p/12518252.html
Copyright © 2011-2022 走看看