Linux进程通信

笔者在学习linux的过程中对linux进程通信进行记录学习。现在在 Linux 中使用较多的进程间通信方式主要有以下几种。

(1)管道(Pipe)及有名管道(named pipe):管道可用于具有亲缘关系进程间的通信, 有名管道,除具有管道所具有的功能外,它还允许无亲缘关系进程间的通信。

(2)信号(Signal):信号是在软件层次上对中断机制的一种模拟,它是比较复杂的通信 方式,用于通知接受进程有某事件发生,一个进程收到一个信号与处理器收到一个中断请求 效果上可以说是一样的。

(3)消息队列:消息队列是消息的链接表,包括 Posix 消息队列 systemV 消息队列。它 克服了前两种通信方式中信息量有限的缺点,具有写权限的进程可以向消息队列中按照一定 的规则添加新消息;对消息队列有读权限的进程则可以从消息队列中读取消息。

(4)共享内存:可以说这是最有用的进程间通信方式。它使得多个进程可以访问同一块 内存空间,不同进程可以及时看到对方进程中对共享内存中数据的更新。这种通信方式需要 依靠某种同步机制,如互斥锁和信号量等。

(5)信号量:主要作为进程间以及同一进程不同线程之间的同步手段。

(6)套接字(Socket):这是一种更为一般的进程间通信机制,它可用于不同机器之间的 进程间通信,应用非常广泛。

管道通信

管道主要有无名管道和有名管道。

无名管道:

它只能用于具有亲缘关系的进程之间的通信(也就是父子进程或者兄弟进程之间)。 ·

它是一个半双工的通信模式,具有固定的读端和写端。 ·

管道也可以看成是一种特殊的文件,对于它的读写也可以使用普通的 read、write 等函数。但是它不是普通的文件,并不属于其他任何文件系统,并且只存在于内存中。

管道的创建与关闭

在管道的创建完成后。会有两个文件描述符对该管道得的读和写进行分别描述。fds[0]用于描述读管道,fds[1]用于描述写管道。

在创建管道时需要使用函数pipe。此函数的头文件包含在#include

所需头文件 #include

函数原型 int pipe(int fd[2])

函数传入值 fd[2]:管道的两个文件描述符,之后就可以直接操作这两个文件描述符 函数返回值 出错返回-1 , 成功返回0。

/*pipe.c*/
#include  //头文件
#include  
#include  
#include  
int main() 
{ 
 int pipe_fd[2]; //定义函数原型
/*创建一无名管道*/ 
 if(pipe(pipe_fd)<0) //如果pipe创建成功返回0,失败则返回-1,然后输出
 { 
 printf("pipe create error\n")

你可能感兴趣的:(linux,运维,服务器)