Linux下进程间通信--管道通信

本文详细介绍了Linux下的进程间通信机制之一——管道通信。包括无名管道和有名管道的创建及使用方法,并通过示例代码展示了如何实现进程间的读写操作。

1.进程间通信 (IPC ) Inter-Process Communication

比较好理解概念的就是进程间通信就是在不同进程之间传播或交换信息

 

2,linux下IPC机制的分类:管道、信号、共享内存、消息队列、信号量、套接字

 

 我今天主要想讲的是管道通信

管道通信特点

     1)管道是最古老的IPC,但目前很少使用
     2)以文件做交互的媒介,管道分为有名管道和无名管道
     3)历史上的管道通常是指半双工管道


1.无名管道的建立:

pipe   建立无名管道

函数原型:int pipe(int  filedes[2])

函数参数:filedes[0] 表示管道读取端;filedes[1] 表示管道写入端

返回值:成功:返回0;失败:返回-1;

#include <unistd.h>
#include <errno.h>
#include <stdio.h>
#include <stdlib.h>

int main()
{
	int pipe_fd[2];
	if(pipe(pipe_fd)<0)
	{
	printf("pipe create error\n");
	return -1;
	}
	else 
		printf("pipe create success\n");
	close(pipe_fd[0]);
	close(pipe_fd[1]);
}


2.创建有名管道

mkfifo

函数原型:int mkfifo(const char *filename,mode_t mode)

函数作用:filename 有名管道的名称,

  mode:有名管道的打开方式(O_NONBLCOK打开fifo文件读取的时候会立刻返回,O_RDONLY只读,O_WRONLY只写,O_RDWR读写)

返回值:成功:0;失败 -1


任意两个进程之间管道之间的读取代码,

#include <sys/types.h>
#include <sys/stat.h>
#include <errno.h>
#include <fcntl.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#define FIFO "/tmp/myfifo"

main(int argc,char** argv)
{
	char buf_r[100];
	int  fd;
	int  nread;
	
	/* 创建管道 */
	if((mkfifo(FIFO,O_CREAT|O_EXCL)<0)&&(errno!=EEXIST))
		printf("cannot create fifoserver\n");
	
	printf("Preparing for reading bytes...\n");
	
	memset(buf_r,0,sizeof(buf_r));
	
	/* 打开管道 */
	fd=open(FIFO,O_RDONLY|O_NONBLOCK,0);
	if(fd==-1)
	{
		perror("open");
		exit(1);	
	}
	while(1)
	{
		memset(buf_r,0,sizeof(buf_r));
		
		if((nread=read(fd,buf_r,100))==-1)
		{
			if(errno==EAGAIN)
				printf("no data yet\n");
		}
		printf("read %s from FIFO\n",buf_r);
		sleep(1);
	}	
	pause(); /*暂停,等待信号*/
	unlink(FIFO); //删除文件
}
#include <sys/types.h>
#include <sys/stat.h>
#include <errno.h>
#include <fcntl.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define FIFO_SERVER "/tmp/myfifo"

main(int argc,char** argv)
{
	int fd;
	char w_buf[100];
	int nwrite;
		
	/*打开管道*/
	fd=open(FIFO_SERVER,O_WRONLY|O_NONBLOCK,0);
	
	if(argc==1)
	{
		printf("Please send something\n");
		exit(-1);
	}
	
	strcpy(w_buf,argv[1]);
	
	/* 向管道写入数据 */
	if((nwrite=write(fd,w_buf,100))==-1)
	{
					printf("The FIFO has not been read yet.Please try later\n");
	}
	else 
		printf("write %s to the FIFO\n",w_buf);
}

任意两个进程之间管道之间的写入代码,这两个代码同时运行的时候,当写入程序写入的时候,另一个就会接收。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值