嵌入式Linux系统:应用开发基础_有名管道通信及例程

本文介绍了嵌入式Linux系统中,有名管道(FIFO)作为进程间通信的一种方式,强调了它能实现无亲缘关系进程间的单向数据传递。详细阐述了FIFO的创建、使用权限以及特点,并通过举例说明如何创建并使用FIFO进行数据传输,展示了在实际项目中的应用。
摘要由CSDN通过智能技术生成

      进程间通信在实际项目中多多少少都会使用到,最常用的有无名管道,有名管道,消息队列,信号,信号量,共享内存等进程间的通信方式。网络通信套字节 socket的方式也可以归为进程通行。

      无名管道只能用于有亲缘进程之间的通信,有名管道可以实现无亲缘关系的通信。有名管道 fifo 给文件系统提供一个路径,这个路径和管道关联,只要知道这个管道路径,就可以进行文件访问,fifo 是指先进先出,也就是先写入的数据,先读出来。

      有名管道:应用于两个进程之间数据的单向传递。在文件目录树上有一个文件标示(管道文件),实际不占磁盘空间,数据缓存在内存中。

有名管道
1、查看命令:man 3 mkfifo

2、头文件:

#include <sys/types.h>
#include <sys/stat.h>

3、函数原型:int mkfifo(const char *pathname, mode_t mode);
a、*pathname:有名管道的名字 例如:/home/gec/myfifo
b、 mode:八进制的权限, 例如:0777

4、返回值:
成功:0
失败-1

5、函数特点:
有名管道存在于文件系统中,提供写入原子性特征,共享内存效率高

6、有名管道的特征:
a、有名字,储存于普通文件系统中
b、任何具有相应权限的进程都可以使用open()来获取FIFO的文件描述符
c、跟普通文件一样,用read()和writ()来读和写
d、不能用lseek来定位
e、具有写入原子性,支持多写者同时进行写操作而数据不会相互践踏

 

下面来写一个例子简单使用管道通信。

写一个maina.c(进程A),一个mainb.c(进程B),一个管道文件fifo。A将hello写入管道中,B将hello读取并打印出来。

 

进程A:

进程B:

只运行A,A进程会阻塞运行,程序不会结束:

再运行B时,A才会运行结束。

反之,先运行B,B会阻塞,再运行A时,B才能解除阻塞。

 

 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值