设为首页 - 加入收藏 ASP站长网(Aspzz.Cn)- 科技、建站、经验、云计算、5G、大数据,站长网!
热搜: 手机 数据 公司
当前位置: 首页 > 服务器 > 搭建环境 > Windows > 正文

Linux下的进程间通信:使用管道和消息队列(7)

发布时间:2019-05-13 20:36 所属栏目:117 来源:Marty Kalin
导读:这个 receiver 程序不会创建消息队列,尽管 API 尽管建议那样。在 receiver 中,对 int qid = msgget(key, 0666 | IPC_CREAT); 的调用可能因为带有 IPC_CREAT 标志而具有误导性,但是这个标志的真实意义是 如果需要

这个 receiver 程序不会创建消息队列,尽管 API 尽管建议那样。在 receiver 中,对

  1. int qid = msgget(key, 0666 | IPC_CREAT);

的调用可能因为带有 IPC_CREAT 标志而具有误导性,但是这个标志的真实意义是如果需要就创建,否则直接获取sender 程序调用 msgsnd 来发送消息,而 receiver 调用 msgrcv 来接收它们。在这个例子中,sender 以 1-1-2-2-3-3 的次序发送消息,但 receiver 接收它们的次序为 3-1-2-1-3-2,这显示消息队列没有被严格的 FIFO 行为所拘泥:

  1. % ./sender
  2. msg1 sent as type 1
  3. msg2 sent as type 1
  4. msg3 sent as type 2
  5. msg4 sent as type 2
  6. msg5 sent as type 3
  7. msg6 sent as type 3
  8.  
  9. % ./receiver
  10. msg5 received as type 3
  11. msg1 received as type 1
  12. msg3 received as type 2
  13. msg2 received as type 1
  14. msg6 received as type 3
  15. msg4 received as type 2

上面的输出显示 senderreceiver 可以在同一个终端中启动。输出也显示消息队列是持久的,即便 sender 进程在完成创建队列、向队列写数据、然后退出的整个过程后,该队列仍然存在。只有在 receiver 进程显式地调用 msgctl 来移除该队列,这个队列才会消失:

  1. if (msgctl(qid, IPC_RMID, NULL) < 0) /* remove queue */

总结

管道和消息队列的 API 在根本上来说都是单向的:一个进程写,然后另一个进程读。当然还存在双向命名管道的实现,但我认为这个 IPC 机制在它最为简单的时候反而是最佳的。正如前面提到的那样,消息队列已经不大受欢迎了,尽管没有找到什么特别好的原因来解释这个现象;而队列仍然是 IPC 工具箱中的一个工具。这个快速的 IPC 工具箱之旅将以第 3 部分(通过套接字和信号来示例 IPC)来终结。


【编辑推荐】

  1. 如何找到并杀死Linux数据中心服务器上的僵尸进程?
  2. Linux网络管理基础知识,看这一篇就够了
  3. 微软变了:Windows未来会成为Linux的一部分?
  4. 借助UKUU在Ubuntu上更新Linux内核
  5. WSL Arch Linux 已在 Microsoft Store 上可用
【责任编辑:庞桂玉 TEL:(010)68476606】
点赞 0

(编辑:ASP站长网)

网友评论
推荐文章
    热点阅读