訊息佇列相關函式總結
訊息佇列
1.msgget
作用:建立訊息佇列
原型:int msgget(key_t key, int msgflag)
引數:key:鍵值 IPC_PRIVATE
msgflag:許可權
返回值:成功:訊息佇列ID
出錯:-1
標頭檔案:sys/tpes.j
sys/ipc.h
sys/shm.h
2.msgsnd
作用:寫資料到訊息佇列
原型:int msgsnd(int msgid, const void *msggp, size_t msgsize, int msgflg)
引數:msggp 訊息結構
struct msgtype
{
long msgtype;
char mtext[1];
}
msgsize 訊息的位元組數
msgflg IPC_NOWAIT 寫不進去訊息直接返回
0阻塞 一直等待到能寫進去訊息為止
3.msgrcv
作用:從訊息佇列中讀資料
原型:ssize_t msgrcv(int msqid, void *msgp, size_t msgsz, long msgtyp, intmsgflg)
引數:msqid:訊息佇列的識別碼。
msgp:指向訊息緩衝區的指標,此位置用來暫時儲存傳送和接收的訊息,是一個使用者可定義的通用結構,形態如下
struct msgbuf {
long mtype; /* 訊息型別,必須 >0 */
char mtext[1]; /* 訊息文字 */
};
msgsz:訊息的大小。
msgtyp:訊息型別
msgtyp等於0 則返回佇列的最早的一個訊息
msgtyp大於0,則返回其型別為mtype的第一個訊息
msgtyp小於0,則返回其型別小於或等於mtype引數的絕對值的最小的一個訊息
4.msgctl
作用:控制訊息佇列
原型:int msggctl(intmsgid, int cmd, struct msgid_ds *buf)
引數:msgid 訊息佇列ID
cmd 命令引數IPC_STAT 讀取訊息佇列的資料結構,儲存在buf指定的地址中
IPC_SET設定訊息佇列資料結構msgid_ds中的IPC操作許可權
IPC_RMID從系統核心彙總刪除訊息佇列
返回值: 成功 0
出錯-1