|
|
EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
一、概念
+ m$ P% F9 r8 m. R1 |/ i: n& Q& g1 [6 D( l8 ^" F
消息队列就是一个消息的链表。可以把消息看作一个记录,具有特定的格式以及特定的优先级。对消息队列有写权限的进程可以向中按照一定的规则添加新消息;有读权限的进程则可以读走消息。读走就没有了。消息队列是随内核持续的。 只有内核重启或人工删除时,该消息才会被删除。在系统范围内,消息队列与键值唯一对应。$ @: ]/ {1 W7 ]3 {+ a9 {3 i
- W' u* V2 z% o' \5 A# |+ e
二、步骤及思路3 d* Y2 m% n' J( c
) V9 q$ l& ?" u
1、取得键值
. m' _. V! ~2 Q# {' b8 i
* G& S$ b" s8 `% o. u3 u2、打开、创建消息队列& W' p4 i" T x0 f
9 x% Z/ G. G B! D& q. c& f; f9 M
3、发送消息
9 R* G- M- E; @) t4 [, s/ G; v+ ~
- W( z3 O* t- z: E% x" d* r4、接收消息
) v6 j2 c" j& b$ n R @9 K& U/ k8 ^
下面具体看看:% x& G2 W' i, |& D: D& l; `
6 A. m* {3 w/ a$ w }1、取得键值6 K! u* G8 K3 U" G6 A
% v7 r) l" N9 I: @& N. q8 _/ c key_t ftok(char *pathname, char proj)
1 J) H3 u- o N. Z! Q2 [6 K( n; I' `/ Z- s7 K
( _ Z0 U$ b3 |& M5 @' N: R1 a
% l6 s; {7 X5 v2 u. W W9 j 头文件为<sys/ipc.h>。返回文件名对应的键值,失败返回 -1。proj是项目名,随便写,不为0就行。3 y! n7 S: q# F3 _: m+ y+ Z4 r
; k- b/ A5 v: N; W3 t1 P( e
fname就是你指定的文件名(已经存在的文件名)。需要有-t 的权限,或用root权限执行,通常设为/tmp或设为" . "。这里我感觉不用这个函数也行,因为key值可以自己指定,例如: #define KEY_MSG 0x101
* B6 I/ Q; r9 Y' D0 o, N6 S; H7 C( p5 @" \3 L: F8 u" H, @
2、打开、创建消息队列, d9 j% d" N$ D" R( l& A
6 T4 k8 n8 r! V/ A! f& q int msgget(key_t key, int msgflg)
% m5 c1 Q' Z' Q. K: D. s; X4 | \9 c+ e, b
$ Z% n( [% d5 Z6 p 头文件为<sys/msg.h>。key由ftok获得。
! z2 [, D. q/ \- i
+ `$ a1 ]8 V, y% I0 K msgflg有:3 f1 n: {- c) L0 h1 A1 N
" q& p6 S" _" |- O; j( x2 ~IPC_CREAT 创建新的消息队列,应配有文件权限0666。9 D. [! ^9 b! Z- p8 g
2 S6 E6 a9 K% B% q, fIPC_EXCL 与IPC_CREAT一同使用,表示如果要创建的消息队列已经存在,则返回错误。3 T" n: |" L" `: \, ~
+ S z8 x1 Z# e6 h( B; uIPC_NOWAIT 读写消息不阻塞。
2 G& t9 y9 ?) m# @: { A# W" F, ^. E% o* u5 o
E& N6 V y% b5 Y+ ` 当没有与key相对应的消息队列并且msgflg中包含了IPC_CREAT标志 或 key的参数为IPC_PRIVATE 时,创建一个新的消息队列。( |- P- s) {+ b9 p3 k
' T2 X5 x0 X* r+ i8 O4 S$ i/ _
3、发送消息6 h! m6 g9 a! Z5 B
. D) M% M6 _: d% |) x: y. `2 o7 P) q: ?
$ U5 P; K* R+ D
0 A. Q: w! g# n+ F7 C
|
|