Linux进程间通信——管道通信详解

引言

进程是相互独立的,每个进程都有自己的虚拟地址空间,虚拟地址空间通过页表的映射,映射到自己的物理内存上,互不影响。正因为如此,进程间通信就变得很麻烦,操作系统为了使进程间能够通信,会提供一个介质,让多个进程都能够访问,也就是在内存上开辟一块公共资源,让进程在公共资源上交流。

进程间通信

在Linux系统中,有时候需要多个进程之间相互协作,共同完成某项任务,进程之间或线程之间有时候需要传递信息,有时候需要同步协调彼此工作,则就会出现进程间通信。
信号也是进程间通信的一种机制,一个进程向另一个进程发送信号,但传送的信息只限于一个信号值。因此我们将介绍以下管道,通过它进程之间可以交换更有用的数据。

管道通信

管道可以用来两个进程之间传递数据,如ps -ef|grep “bash”,其中| 就是管道,作用就是将ps命令的结果写入管道文件,然后grep在从管道文件中读出该数据进行过滤。也就是连接一个读进程和一个写进程,以实现他们通信的一个共享文件。
在这里插入图片描述
**管道特性:不能能在创建时就确定确定数据流向(操作系统无法确定谁读谁写),而是在使用的时候确定,因此操作系统会提供两个描述符供使用,一个读一个写,这样的确定方向就是将对应的一段关闭掉即可,这样方向的控制权就交给了用户。

有名管道

概念

在文件系统目录中存在一个管道文件,它也仅仅是文件系统中的一个标识,并没有在磁盘上占据空间,在使用的时候在内存上开辟空间,作为两个进程数据交互的通道。

创建和打开

1、命令创建:

mkfifo filename

在这里插入图片描述
2、通过mkfifo函数,在代码中创建管道文件

#include<sys/type.h>
#include<sys/stat.h>
int mkfifo(const char* filename,mode_t mode)

第一个参数代表路径,第二个参数代表权限值。

通信原理

以只写方式打开,写端,

#include<stdio.h>
#include<stdlib.h>
#include<unistd.h>
#include<string.h>
#include<assert.h>
#include<fcntl.h>

int main()
{
   
	int fd = open("fifo",O_WRONLY);
	assert(fd != -1);
	printf("fd:%d\n",fd);
	while(1)
	{
   
		char buff[128] = {
   0};
		printf("input:\n");
		fgets(buff,128,stdin);
		if
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值