知识讲解Unix 消息队列

系统 其他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消息队列具体问题
责任编辑:小霞
相关推荐

2010-04-21 12:12:56

Unix 消息队列

2010-04-13 17:00:43

Unix消息队列

2010-05-05 13:13:55

Unix内核

2010-04-30 13:27:26

Unix cronta

2010-05-05 13:45:21

Unix Telnet

2010-05-04 12:25:28

Unix链接

2010-04-30 13:38:51

Unix at命令

2010-05-04 09:22:10

Unix文件

2010-05-04 16:33:39

Unix系统

2010-05-05 10:44:37

Unix 反引号

2010-05-05 15:02:39

Unix系统

2010-05-05 13:22:29

Unix Shell

2010-04-21 14:29:52

Unix 线程

2010-04-13 17:52:16

Unix交换区

2010-04-30 18:20:23

Unix系统

2010-05-04 09:45:28

Unix系统

2010-04-21 14:39:59

Unix消息队列

2010-04-21 14:49:13

Unix消息队列

2010-04-30 01:28:59

Unix系统

2010-05-06 14:24:56

Unix系统交换区
点赞
收藏

51CTO技术栈公众号