笔者在学习linux的过程中对linux进程通信进行记录学习。现在在 Linux 中使用较多的进程间通信方式主要有以下几种。
(1)管道(Pipe)及有名管道(named pipe):管道可用于具有亲缘关系进程间的通信, 有名管道,除具有管道所具有的功能外,它还允许无亲缘关系进程间的通信。
(2)信号(Signal):信号是在软件层次上对中断机制的一种模拟,它是比较复杂的通信 方式,用于通知接受进程有某事件发生,一个进程收到一个信号与处理器收到一个中断请求 效果上可以说是一样的。
(3)消息队列:消息队列是消息的链接表,包括 Posix 消息队列 systemV 消息队列。它 克服了前两种通信方式中信息量有限的缺点,具有写权限的进程可以向消息队列中按照一定 的规则添加新消息;对消息队列有读权限的进程则可以从消息队列中读取消息。
(4)共享内存:可以说这是最有用的进程间通信方式。它使得多个进程可以访问同一块 内存空间,不同进程可以及时看到对方进程中对共享内存中数据的更新。这种通信方式需要 依靠某种同步机制,如互斥锁和信号量等。
(5)信号量:主要作为进程间以及同一进程不同线程之间的同步手段。
(6)套接字(Socket):这是一种更为一般的进程间通信机制,它可用于不同机器之间的 进程间通信,应用非常广泛。
管道通信
管道主要有无名管道和有名管道。
无名管道:
它只能用于具有亲缘关系的进程之间的通信(也就是父子进程或者兄弟进程之间)。 ·
它是一个半双工的通信模式,具有固定的读端和写端。 ·
管道也可以看成是一种特殊的文件,对于它的读写也可以使用普通的 read、write 等函数。但是它不是普通的文件,并不属于其他任何文件系统,并且只存在于内存中。
管道的创建与关闭
在管道的创建完成后。会有两个文件描述符对该管道得的读和写进行分别描述。fds[0]用于描述读管道,fds[1]用于描述写管道。
在创建管道时需要使用函数pipe。此函数的头文件包含在#include<unistd.h>。
所需头文件 #include
函数原型 int pipe(int fd[2])
函数传入值 fd[2]:管道的两个文件描述符,之后就可以直接操作这两个文件描述符 函数返回值 出错返回-1 , 成功返回0。
/*pipe.c*/
#include <unistd.h> //头文件
#include <errno.h>
#include <stdio.h>
#include <stdlib.h>
int main()
{
int pipe_fd[2]; //定义函数原型
/*创建一无名管道*/
if(pipe(pipe_fd)<0) //如果pipe创建成功返回0,失败则返回-1,然后输出
{
printf("pipe create error\n")