【APUE】进程间通信之FIFO

FIFO也称为有名管道,它是一种文件类型。FIFO简单理解,就是它能把两个不相关的进程联系起来,FIFO就像一个公共通道,解决了不同进程之间的“代沟”。普通的无名管道只能让相关的进程进行沟通(比如父shell和子shell之间)。

创建FIFO类似于创建文件

#include <sys/stat.h>

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

FIFO的出现,极好地解决了系统在应用过程中产生的大量的中间临时文件的问题。FIFO可以被shell调用使数据从一个进程到另一个进程,系统不必为 该中间通道去烦恼清理不必要的垃圾,或者去释放该通道的资源,它可以被留做后来的进程使用。并且规避了匿名管道在作用域的限制,可应用于不相关的进程之间。

FIFO由下面两种用途:

1)FIFO由shell命令使用以便将数据从一条管道线传送到另一条,为此无需创建中间文件

2)FIFO用于客户进程-服务器进程应用程序中,以在客户进程和服务器进程之间传递数据

http://blog.csdn.net/MONKEY_D_MENG/article/details/5651430

【APUE】进程间通信之FIFO

时间: 2024-08-09 10:43:57

【APUE】进程间通信之FIFO的相关文章

Linux 系统开发5 进程间通信 pipe() fifo() mmap()

[本文谢绝转载,原文来自http://990487026.blog.51cto.com] Linux 系统开发5 进程间通信 pipe() fifo() mmap() pipe()管道通信介绍 pipe()父子进程通信案例 pipe()使用管道有一些限制 pipe()管道缓存区大小 pipe() 读端非阻塞管道 fifo()管道文件 fifo()写端/读端程序 管道文件在磁盘上的大小是0 mmap()将文件映射到内存 mmap()写端/读端程序 mmap()传输结构体数据,删除临时文件 pipe

linux 进程间通信 之fifo

上一篇博客已经介绍了一种进程间通信的方式,但是那只是针对于有血缘关系的进程,即父子进程间的通信,那对于没有血缘关系的进程,那要怎么通信呢?  这就要创建一个有名管道,来解决无血缘关系的进程通信, fifo: [email protected]:~$ mkfifo xwp [email protected]:~$ ls -l myfifo prw-rw-r-- 1 book book 0 Feb 6 2016 myfifo mkfifo 既有命令也有函数 #include <sys/types.h

3.2 进程间通信之fifo

一.引言 FIFO常被称为有名管道,不同于管道(pipe).pipe仅适用于"有血缘关系"的IPC.但FIFO还可以应用于不相关的进程的IPC.实际上,FIFO是Linux基础文件类型中的一种,是在读写内核通道. 函数原型: int mkfifo(const char *pathname, mode_t mode); 成功返回 0, 失败返回 -1 命令: mkfifo + 管道名   例:mkfifo fifo_one 操作步骤: 1) 通过命令行创建fifo: 2) 使用open.

管道容量及缓冲区的组成

每个进程都有不同的用户地址空间,任何一个进程的全局变量在 另一个进程中都看不到,所以进程之间要交换数据必须 通过内核,在内核中开辟一块缓冲区,把进程1的数据从用户空间考到内核区,进程2再从内核区把数据考走,内核提供的这种机制叫做进程间通信 (一)管道的外部实现 当我们定义一个管道时,这个管道是由内核管理的一个缓冲区,可以抽象为现实生活中的线路:管道的一端链接一个进程的输出 ,这个进程 会向管道中放入信息:管道的另一端链接一个进程的输出,这个进程取出被放入的信息.当管道被放满时尝试放入信息的进程会

Linux文件类型详解

一.Linux文件类型分:普通文件.目录文件.链接文件.设备文件.管道文件. 1.普通文件:由ls -al显示属性时,第一个属性为 [-],例如 [-rwxrwxrwx].包括: 1.纯文本文件(ASCII):是内容可以直接读到的数据,例如 数字.字母等等. 2.二进制文件(binary):图片.音频.视频文件. 3.数据格式文件(data):某些程序在运行过程中,会读取特定格式的文件,这些特定格式的文件可以称为数据文件(datafile). 2.目录文件(directory)(目录或文件夹),

Python3 与 C# 并发编程之~ 进程先导篇

Linux专项¶ 先写几个问号来概况下今天准备说的内容:(谜底自己解开,文中都有) 你知道Ctrl+C终止进程的本质吗?你知道Kill -9 pid的真正含义吗? 你知道那些跨平台框架(Python,NetCore)在Linux下创建进程干了啥? 你了解僵尸进程和孤儿进程的悲催生产史吗?孤儿找干爹,僵尸送往生想知道不? 想知道创建子进程后怎么李代桃僵吗?ps aux | grep xxx的背后到底隐藏了什么? 你了解Linux磁盘中p类型的文件到底是个啥吗? 为什么要realase发布而不用de

(十二) 一起学 Unix 环境高级编程 (APUE) 之 进程间通信(IPC)

. . . . . 目录 (一) 一起学 Unix 环境高级编程 (APUE) 之 标准IO (二) 一起学 Unix 环境高级编程 (APUE) 之 文件 IO (三) 一起学 Unix 环境高级编程 (APUE) 之 文件和目录 (四) 一起学 Unix 环境高级编程 (APUE) 之 系统数据文件和信息 (五) 一起学 Unix 环境高级编程 (APUE) 之 进程环境 (六) 一起学 Unix 环境高级编程 (APUE) 之 进程控制 (七) 一起学 Unix 环境高级编程 (APUE)

进程间通信之管道(pipe、fifo)

我们先来说说进程间通信(IPC)的一般目的,大概有数据传输.共享数据.通知事件.资源共享和进程控制等.但是我们知道,对于每一个进程来说这个进程看到属于它的一块内存资源,这块资源是它所独占的,所以进程之间的通信就会比较麻烦,原理就是需要让不同的进程间能够看到一份公共的资源.所以交换数据必须通过内核,在内核中开辟?块缓冲区,进程1把数据从?户空间 拷到内核缓冲区,进程2再从内核缓冲区把数据读?,内核提供的这种机制称为进程间通信.一般我们采用的进程间通信方式有 管道(pipe)和有名管道(FIFO)

进程间通信 ---- 管道与FIFO 用法技巧

1.管道的创建 1.1 mkfifo(const char *pathname,mode_t mode); 函数已隐含指定O_CREAT|O_EXCL,所以它要么创建一个新的FIFO,要么返回EEXIST错误(已存在). 所以在创建已存在FIFO或新的FIFO,应该先调用mkfifo,并检查返回值 是否是EEXIST错误,若是EEXIST错误,则调      用open函数. 2.FIFO或管道读写 2.1对管道或FIFO的write 总是往末尾添加数据,对管道或FIFO的read总是从头开始读