Linux 进程通信fifo,Linux 进程通信之FIFO的实现

fifo通信(first in first out)

fifo 有名管道,实现无血缘关系进程通信。

创建一个管道的伪文件

a.mkfifo testfifo 命令创建

b.也可以使用函数int mkfifo(const char *pathname, mode_t mode);

内核会针对fifo文件开辟一个缓冲区,操作fifo文件,可以操作缓冲区,实现进程间通信–实际上就是文件读写

man 3 mkfifo

#include

#include

int mkfifo(const char *pathname, mode_t mode);

注意事项:

fifos

opening the read or write end of a fifo blocks until the other end is also opened (by another process or thread). see

fifo(7) for further details.

打开fifo文件时候,read端会阻塞等待write端open,write端同理,也会阻塞等待另外一段打开。

代码示例:

file_w.c 写端

#include

#include

#include

#include

#include

#include

#include

#include

int main(int argc, char *argv[]) {

if(argc != 2) {

printf("./a.out filename1\n");

return -1;

}

printf("begin open w\n");

int o_ret = open(argv[1], o_wronly);

printf("end open w\n");

char buf[256];

int num = 0;

while (1) {

memset(buf, '\0', sizeof(buf));

sprintf(buf, "xiaoming--%d", num++);

printf("strlen(buf) = %d\n", strlen(buf));

write(o_ret, buf, strlen(buf));

sleep(1);

}

close(o_ret);

return 0;

}

file_r.c 读端

#include

#include

#include

#include

#include

#include

#include

#include

int main(int argc, char *argv[]) {

if(argc != 2) {

printf("./a.out filename1\n");

return -1;

}

printf("begin open r\n");

int o_ret = open(argv[1], o_rdonly);

printf("end open r\n");

char buf[256];

int num = 0;

while (1) {

memset(buf, '\0', sizeof(buf));

read(o_ret, buf, sizeof(buf));

printf("strlen(buf) = %d\n", strlen(buf));

printf("read is%s\n", buf);

}

close(o_ret);

return 0;

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持萬仟网。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值