欢迎访问生活随笔!

生活随笔

您现在的位置是:首页 > 形式科学 > 操作系统 > 其他OS

其他OS

知识讲解Unix 消息队列

发布时间:2022-06-22其他OS 系统管理员
我们在文章中会来学习一下Unix 消息队列的知识,Unix 操作系统是一个分时的多任务操作系统 ,所有的消息都放在系统内核当中 , 并且它们都有一个相应的Unix 消息队列标识符。

由于经常学习Unix操作系统的一些知识,今天,我们来学习一下Unix 消息队列的知识,在传统的单任务操作系统中 , 程序设计的对象一经运行 , 程序就将独占整个主机资源, 程序实体之间的不同模块完全是通过全局变量、函数调用时的参数返回值来进行通信的。

Unix 操作系统是一个分时的多任务操作系统 , 程序运行后都将成为一个独立的实体——进程 , 进程间的通信不仅包括其内部通信 , 还包括进程间的通信。UNIX System V 中提供了一系列的进程通信机构 , 即 IPC 机构 ,Unix 消息队列就是其中之一。

在 Unix 系统中 , 所有的消息都放在系统内核当中 , 并且它们都有一个相应的Unix 消息队列标识符。进程可读写任意队列中特定的消息 , 其次序是消息到达的次序 , 核心负责维护这一适当的次序 , 而且在同一Unix 消息队列中 , 不同的进程可分别读出各自需要的消息 , 在其它进程向Unix 消息队列写入消息之前 , 进程可一直读取消息而不必等待消息到达队列。

每一个位于Unix 消息队列中的消息都包括如下内容 :
1. 长整数类型 : 定义消息类型
2. 消息的数据长度 : 定义数据长度
3. 数据 : 具体内容

系统内核为Unix 消息队列维持如下数据结构信息 , 其定义包含在 <msg.h> 头文件中 :
 

  1. struct msqid_ds{   
  2. struct ipc_perm msg_perms; /*operation permission struct*/   
  3. struct msg *msg_first;   
  4. /*ptr to first message on q*/   
  5. struct msg *msg_last;   
  6. /*ptr to last message on q*/   
  7. ushort   
  8. msg_cbytes;   
  9. /*current num bytes on q*/   
  10. ushort   
  11. msg_qnum;   
  12. /*no.message on q*/   
  13. ushort   
  14. msg_qbuyes;   
  15. /*max no.bytes for q*/   
  16. ushort   
  17. msg_lspid;   
  18. /*pid of last megsnd*/   
  19. ushort   
  20. msg_lrpid;   
  21. /*pid of last msgrcv*/   
  22. time_t   
  23. msg_stime;   
  24. /*last msgsnd time*/   
  25. time_t   
  26. msg_rtime;   
  27. /*last msgrcv time*/   
  28. time_t   
  29. msg_ctime;   
  30. /*last change time*/  

类型 ushort 和 time_t 与系统实现有关 , 它们包含在头文件 <types.h> 中定义 ;ipc_perm 结构包含了对应Unix 消息队列的主人和存取权限 ; 结构 msg 被内核用来把某一队列上的消息链接为队列。

这次,关于Unix 消息队列的知识,我们就讲解到这里了。希望大家能够好好的学习这部分知识。

【编辑推荐】

  1. Linux多线程同步之消息队列
  2. 详解Unix消息队列知识
  3. VB.NET消息队列相关内容详细介绍
  4. WCF消息队列系列介绍
  5. 说明WCF消息队列具体问题