linux的进程间通信概述

一 进程间通信

  1.1. linux内核提供多种进程间通信机制

    a. 无名管道和有名管道

    b. SystemV IPC:信号量、消息队列、共享内存

    c. Socket域套接字

    d. 信号

  1.2. 无名管道和有名管道

    1.2.1. 管道(无名管道)

      a. 管道通信的原理:内核维护的一块内存,有读端和写端(管道是单向通信的)
      b. 管道通信的方法:父进程创建管理后fork子进程,子进程继承父进程的管道fd
      c. 管道通信的限制:只能在父子进程间通信、半双工
      d. 管道通信的函数:pipe、write、read、close
    1.2.2. 有名管道(fifo)
      a. 有名管道的原理:实质也是内核维护的一块内存,表现形式为一个有名字的文件
      b. 有名管道的使用方法:固定一个文件名,2个进程分别使用mkfifo创建fifo文件,然后分别open打开获取到fd,然后一个读一个写
      c. 管道通信限制:半双工(注意不限父子进程,任意2个进程都可)
      d. 管道通信的函数:mkfifo、open、write、read、close

  1.3. SystemV IPC介绍

    1.3.1. SystemV IPC的基本特点

      a. 系统通过一些专用API来提供SystemV IPC功能

      b. 分为:信号量、消息队列、共享内存

      c. 其实质也是内核提供的公共内存

    1.3.2. 消息队列

      a. 本质上是一个队列,队列可以理解为(内核维护的一个)FIFO

    1.3.3. 信号量

      a. 实质就是个计数器(其实就是一个可以用来计数的变量,可以理解为int a)
      b. 通过计数值来提供互斥和同步

    1.3.4. 共享内存

      a. 大片内存直接映射
      b. 类似于LCD显示时的显存用法

 

 

 

  

posted @ 2019-03-12 23:00  三七鸽  阅读(169)  评论(0编辑  收藏  举报