当前位置:网站首页>unix环境编程 第十五章 15.5FIFO
unix环境编程 第十五章 15.5FIFO
2022-08-09 10:26:00 【玛丽苏打肉饼】
FIFO有时被命名为管道。通过FIFO,不相关的进程也能交换数据。
创建FIFO类似于创建文件
#include <sys/stat.h>
int mkfifo(const char *path,mode_t mode);
int mkfifoat(int fd,const char *path,mode_t mode);
//成功返回0,出错返回-1
mode参数的规格说明与open函数中的mode的相同。
当open一个FIFO时,非阻塞标志会产生下列影响:
- 在一般情况下,制度open阻塞到其他进程为写而打开这个FIFO为止。类似的,只写open要阻塞到某个其他进程为读而打开它为止。
- 如果指定了O_NONBLOCK,则只读open立即返回。但是,如果没有进程为读而打开一个FIFO,那么只写open将返回-1,并将errno设置成ENXIO。
一个给定的FIFO有多个写进程时常见的,这就意味着,如果不希望多个进程所写的数据交叉,则必须考虑原子操作。
FIFO有以下两种用途:
- shell命令使用FIFO将数据从一条管道传送到另外一条管道的时候,无需创建中间临时文件。
- 客户进程-服务器进程应用程序中,FIF用作汇聚点,在客户进程和服务器进程二者之间传递数据。
边栏推荐
- 实现下拉加载更多
- 2022强网杯WP
- Quick sort eight sorts (3) 】 【 (dynamic figure deduction Hoare, digging holes, front and rear pointer method)
- 学习NET-SNMP之二-----------VisualStudio编译Net-SNMP
- 自启服务mock联调跨域问题
- 对话跨国消费品牌DPO:数据安全合规从何做起?8.11直播见!
- Loop nesting and basic operations on lists
- MySQL索引的B+树到底有多高?
- 动态内存管理
- [Halcon&几何] 直线的垂线与延长线的计算
猜你喜欢
随机推荐
KMP& sunday
基于信号量与环形队列实现读写异步缓存队列
需求侧电力负荷预测(Matlab代码实现)
可能95%的人还在犯的PyTorch错误
京东物流与五菱将开发联名版定制产品
MySQL执行过程及执行顺序
Throwing a question? The execution speed of the Count operation in the Mysql environment is very slow. You need to manually add an index to the primary key---MySql optimization 001
相伴成长,彼此成就 用友U9 cloud做好制造业数智化升级的同路人
cannot import name ‘load_offloaded_weights‘ from ‘accelerate.utils‘ (/home/huhao/anaconda3/envs/huha
实现下拉加载更多
Umi Hooks
xmms播放器加了播放列表的管理功能
Electron application development best practices
机器学习-逻辑回归(logistics regression)
[贴装专题] 贴装流程中涉及到的位置关系计算
收到人生第一笔五位数工资
MySQL备份与恢复
按键精灵之输出文本
The GNU Privacy Guard
OpenGL ES2.0编程三部曲(转载自MyArrow)