目次
3. 2つのプロセスは、よく知られたパイプを介して通信します
1.よく知られているパイプラインの概要
2.FIFOファイルを作成します
方法1:コマンド経由:mkfifo name
方法2:関数mkfifoを使用
1.通过命令: mkfifo 名字
2.通过函数: int mkfifo(const char *pathname, mode_t mode);
#include <sys/types.h>
#include <sys/stat.h>
int mkfifo(const char *pathname, mode_t mode);
参数:
-pathname:管道名称的路径
-mode:文件的权限,和open的mode是一样的,是一个八进制的数
返回值:成功返回0,失败返回-1,并设置errno
プログラム例:
#include <sys/stat.h>
#include <sys/types.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
int main()
{
//判断管道文件fifo1是否存在
int ret = access("fifo1", F_OK);
if (ret == -1)
{
printf("fifo1不存在,创建fifo1\n");
ret = mkfifo("fifo1", 0664);
if (ret == -1)
{
perror("mkfifo");
return -1;
}
}
return 0;
}
演算結果:
3. 2つのプロセスは、よく知られたパイプを介して通信します
ファイルwrite.c:
#include <sys/stat.h>
#include <sys/types.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <fcntl.h>
#include <string.h>
int main()
{
//判断管道文件fifo1是否存在
int ret = access("fifo1", F_OK);
//如果不存在,创建管道文件
if (ret == -1)
{
printf("fifo1不存在,创建fifo1\n");
ret = mkfifo("fifo1", 0664);
if (ret == -1)
{
perror("mkfifo");
return -1;
}
}
//以只写方式打开管道文件
int fd=open("fifo1",O_WRONLY);
if(fd==-1)
{
perror("open");
return -1;
}
//往管道中写数据
char buf[1024]={0};
for(int i=0;i<100;i++)
{
sprintf(buf,"hello:%d\n",i);
printf("write:%s\n",buf);
write(fd,buf,strlen(buf));
bzero(buf,1024);
sleep(1);
}
close(fd);
return 0;
}
ファイルread.c:
#include <sys/stat.h>
#include <sys/types.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <fcntl.h>
#include <string.h>
int main()
{
//以只读方式打开管道
int fd=open("fifo1",O_RDONLY);
if(fd==-1)
{
perror("open");
return -1;
}
//从管道中读数据
char buf[1024]={0};
while(1)
{
int len=read(fd,buf,sizeof(buf));
if(len==0)
{
printf("写端断开连接\n");
break;
}
else if(len>0)
{
printf("read recv:%s\n",buf);
bzero(buf,1024);
/* code */
}
}
return 0;
}
実行結果:(2つの端末で)
有名なパイプに関する注意:
1.プロセスがパイプの読み取り専用端を開いた後、別のプロセスがパイプの書き込み専用端を開くまでブロックします
2.プロセスがパイプの書き込み専用端を開いた後、別のプロセスがパイプの読み取り専用端を開くまでブロックします
パイプラインの読み取り:
パイプラインにデータがあります。readは実際に読み取られたバイト数を返します
パイプラインにデータがありません:
パイプのすべての書き込み端が閉じている場合、読み取りは0を返します(ファイルの最後までの読み取りに相当)
書き込み終了が閉じられていない場合は、ブロックを読み取って待機します
パイプラインを書く:
すべてのパイプ読み取り終了が閉じられます:プロセスが異常終了します(SIGPIPE信号を受信しました)
パイプの読み取り端がすべて閉じているわけではありません。
パイプラインがいっぱいです、書き込みはブロックされます
パイプラインがいっぱいではありません。writeはデータを書き込み、実際に書き込まれたバイト数を返します。