在两个终端里用 gcc 分别编译运行上面两个文件,可以看到输出结果如下:
[$ ./write_fifo ]
I am 7872 process
Send message: Process 7872's time is Mon Jan 16 18:00:23 2023
Send message: Process 7872's time is Mon Jan 16 18:00:24 2023
Send message: Process 7872's time is Mon Jan 16 18:00:25 2023
Send message: Process 7872's time is Mon Jan 16 18:00:26 2023
Send message: Process 7872's time is Mon Jan 16 18:00:27 2023
Send message: Process 7872's time is Mon Jan 16 18:00:28 2023
Send message: Process 7872's time is Mon Jan 16 18:00:29 2023
Send message: Process 7872's time is Mon Jan 16 18:00:30 2023
Send message: Process 7872's time is Mon Jan 16 18:00:31 2023
Send message: Process 7872's time is Mon Jan 16 18:00:32 2023
[$ ./write_fifo ]
I am 7872 process
Send message: Process 7872's time is Mon Jan 16 18:00:23 2023
Send message: Process 7872's time is Mon Jan 16 18:00:24 2023
Send message: Process 7872's time is Mon Jan 16 18:00:25 2023
Send message: Process 7872's time is Mon Jan 16 18:00:26 2023
Send message: Process 7872's time is Mon Jan 16 18:00:27 2023
Send message: Process 7872's time is Mon Jan 16 18:00:28 2023
Send message: Process 7872's time is Mon Jan 16 18:00:29 2023
Send message: Process 7872's time is Mon Jan 16 18:00:30 2023
Send message: Process 7872's time is Mon Jan 16 18:00:31 2023
Send message: Process 7872's time is Mon Jan 16 18:00:32 2023
上面的例子可以扩展成 客户端进程—服务端进程通信的实例,write_fifo的作用类似于客户端,可以打开多个客户端向一个服务器发送请求信息,read_fifo类似于服务器,它适时监控着FIFO的读端,当有数据时,读出并进行处理,但是有一个关键的问题是,每一个客户端必须预先知道服务器提供的FIFO接口,下图显示了这样的操作:
三、消息队列
消息队列,是消息的链接表,存放在内核中。一个消息队列由一个标识符(即队列ID)来标识。
1、特点
- 消息队列是面向记录的,其中的消息具有特定的格式以及特定的优先级。
- 消息队列独立于发送与接收进程。进程终止时,消息队列及其内容并不会被删除。
- 消息队列可以实现消息的随机查询,消息不一定要以先进先出的次序读取,也可以按消息的类型读取。
2、原型
// 创建或打开消息队列:成功返回队列ID,失败返回-1
intmsgget(key_t key, int flag);
// 添加消息:成功返回0,失败返回-1
intmsgsnd(int msqid, constvoid ptr, size_t size, int flag);
// 读取消息:成功返回消息数据的长度,失败返回-1
intmsgrcv(int msqid, void* ptr, size_t size, long type, int flag);
// 控制消息队列:成功返回0, 失败返回-1
intmsgctl(int msqid, int cmd, struct msqid_ds * buf);
在以下两种情况下,msgget将创建一个新的消息队列:
- 如果没有与键值key相对应的消息队列,并且flag中包含了
IPC_CREAT
标志位。 - key参数为IPC_PRIVATE。
函数msgrcv在读取消息队列时,type参数有下面几种情况:
- type == 0,返回队列中的第一个消息;
- type > 0,返回队列中消息类型为 type 的第一个消息;
- type < 0,返回队列中消息类型值小于或等于 type 绝对值的消息,如果有多个,则取类型值最小的消息。
可以看出,type值非 0 时用于以非先进先出次序读消息。也可以把 type 看做优先级的权值。(其他的参数解释,请自行Google之)
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。
举报投诉
-
Linux
+关注
关注
87文章
11354浏览量
210659 -
IPC
+关注
关注
3文章
353浏览量
52122 -
进程间通信
+关注
关注
0文章
16浏览量
2458
发布评论请先 登录
相关推荐
Linux现有的所有进程间IPC方式
在开始回答前,先简单概括性地说说Linux现有的所有进程间IPC方式:1. **管道:**在创建时分配一个page大小的内存,缓存区大小比较有限;2
发表于 08-20 06:17
Linux进程间的五种通信方式介绍 3
进程间通信(IPC,InterProcess Communication)是指在不同进程之间传播或交换信息。IPC的方式通常有管道(包括无名
Linux进程间的五种通信方式介绍 4
进程间通信(IPC,InterProcess Communication)是指在不同进程之间传播或交换信息。IPC的方式通常有管道(包括无名
Linux进程间的五种通信方式介绍 6
进程间通信(IPC,InterProcess Communication)是指在不同进程之间传播或交换信息。IPC的方式通常有管道(包括无名
Linux进程间的五种通信方式介绍 5
进程间通信(IPC,InterProcess Communication)是指在不同进程之间传播或交换信息。IPC的方式通常有管道(包括无名
评论