知識(shí)講解Unix 消息隊(duì)列
由于經(jīng)常學(xué)習(xí)Unix操作系統(tǒng)的一些知識(shí),今天,我們來學(xué)習(xí)一下Unix 消息隊(duì)列的知識(shí),在傳統(tǒng)的單任務(wù)操作系統(tǒng)中 , 程序設(shè)計(jì)的對(duì)象一經(jīng)運(yùn)行 , 程序就將獨(dú)占整個(gè)主機(jī)資源, 程序?qū)嶓w之間的不同模塊完全是通過全局變量、函數(shù)調(diào)用時(shí)的參數(shù)返回值來進(jìn)行通信的。
Unix 操作系統(tǒng)是一個(gè)分時(shí)的多任務(wù)操作系統(tǒng) , 程序運(yùn)行后都將成為一個(gè)獨(dú)立的實(shí)體——進(jìn)程 , 進(jìn)程間的通信不僅包括其內(nèi)部通信 , 還包括進(jìn)程間的通信。UNIX System V 中提供了一系列的進(jìn)程通信機(jī)構(gòu) , 即 IPC 機(jī)構(gòu) ,Unix 消息隊(duì)列就是其中之一。
在 Unix 系統(tǒng)中 , 所有的消息都放在系統(tǒng)內(nèi)核當(dāng)中 , 并且它們都有一個(gè)相應(yīng)的Unix 消息隊(duì)列標(biāo)識(shí)符。進(jìn)程可讀寫任意隊(duì)列中特定的消息 , 其次序是消息到達(dá)的次序 , 核心負(fù)責(zé)維護(hù)這一適當(dāng)?shù)拇涡?, 而且在同一Unix 消息隊(duì)列中 , 不同的進(jìn)程可分別讀出各自需要的消息 , 在其它進(jìn)程向Unix 消息隊(duì)列寫入消息之前 , 進(jìn)程可一直讀取消息而不必等待消息到達(dá)隊(duì)列。
每一個(gè)位于Unix 消息隊(duì)列中的消息都包括如下內(nèi)容 :
1. 長整數(shù)類型 : 定義消息類型
2. 消息的數(shù)據(jù)長度 : 定義數(shù)據(jù)長度
3. 數(shù)據(jù) : 具體內(nèi)容
系統(tǒng)內(nèi)核為Unix 消息隊(duì)列維持如下數(shù)據(jù)結(jié)構(gòu)信息 , 其定義包含在 <msg.h> 頭文件中 :
- struct msqid_ds{
- struct ipc_perm msg_perms; /*operation permission struct*/
- struct msg *msg_first;
- /*ptr to first message on q*/
- struct msg *msg_last;
- /*ptr to last message on q*/
- ushort
- msg_cbytes;
- /*current num bytes on q*/
- ushort
- msg_qnum;
- /*no.message on q*/
- ushort
- msg_qbuyes;
- /*max no.bytes for q*/
- ushort
- msg_lspid;
- /*pid of last megsnd*/
- ushort
- msg_lrpid;
- /*pid of last msgrcv*/
- time_t
- msg_stime;
- /*last msgsnd time*/
- time_t
- msg_rtime;
- /*last msgrcv time*/
- time_t
- msg_ctime;
- /*last change time*/
類型 ushort 和 time_t 與系統(tǒng)實(shí)現(xiàn)有關(guān) , 它們包含在頭文件 <types.h> 中定義 ;ipc_perm 結(jié)構(gòu)包含了對(duì)應(yīng)Unix 消息隊(duì)列的主人和存取權(quán)限 ; 結(jié)構(gòu) msg 被內(nèi)核用來把某一隊(duì)列上的消息鏈接為隊(duì)列。
這次,關(guān)于Unix 消息隊(duì)列的知識(shí),我們就講解到這里了。希望大家能夠好好的學(xué)習(xí)這部分知識(shí)。
【編輯推薦】