进程间通讯:
A 进程将“hello world”传递给 B 进程。
1.1 管道实现原理
![这里写图片描述](https://img-blog.csdn.net/20170930163226509?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvU2FrdXJhX2NoZXJyeQ==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
通过在内存上开辟一块全新的空间,A,B 进程都通过文件描述符操作这块空间。以完成数据交互的功能。
1.2. 创建管道文件命令:
mkfifo 命令 mkfifo();函数
1.3 使用管道文件传递信息:
打开: open
读取数据:read
写数据: write
关闭: close
1.4 管道文件操作特点:
如果一个进程以只写打开管道,但是没有以只读或读写打开这个管道的进程,则打开操作会阻塞, 直到有进程以读或读写打开,open 才会返回。
如果一个进程以只读打开管道,但是没有以只写或读写打开这个管道的进程,则打开操作会阻塞, 直到有进程以写或读写打开,open 才会返回。
当写端没有写入数据时,读端会阻塞到 read 调用,直到写端写入数据或者写端关闭。
当管道没有空间时,再写入数据就会被阻塞。直到有进程读取数据,或者所有的读端关闭。
练习:
A 进程接受用户输入,B 进程统计用户输入的字符个数。当用户输入 end 结束,并且 end 不做统计。
写文件方的代码:
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<unistd.h>
#include<fcntl.h>
#include<assert.h>
void main()
{
int ptr=open("./FIFO",O_WRONLY); //以只写方式打开存储在指定路径下的管道文件
assert(ptr != -1); //打开失败,返回值为-1
printf("open FIFO success\n");
while(1) //循环写入
{
char p[128]={0};
fgets(p,127,stdin); //将用户输入的字符先存进数组中
write(ptr,p,strlen(p)); //将数组中的字符写入管道文件中
if(strncmp(p,"end",3)== 0) //如果用户输入“end”,结束循环
{
break;
}
}
printf("write FIFO success\n");
close(ptr); //关闭文件
}
接收信息方:
void main()
{
int fd = open("FIFO",O_RDONLY);//以只读方式打开需要接收信息所在的文件
assert(fd != -1);
int count = 0; //记录字符个数
char buff[128]={0};
int res=read(fd,buff,127); //res记录从文件读到数组的准确大小
while(strncmp(buff,"end",3)!= 0)//当用户输入“end”时,如果是从字符中判断是否存在“end”,要用strstr
{
int i=0;
count=res-1;
res=read(fd,buff,127); //继续读
}
printf("%d\n",count);
}