消息队列

消息队列操作基本步骤:

1,key_t ftok( const char *fname, int id )

获取键值

2,int msgget( key_t key, int flag )

打开或创建一个新队列

创建IPC结构条件(满足一个):

一:key是IPC_PRIVATE

二:key当前未与特定类型的IPC结构相结合,并且flag中指定了IPC_CREAT位

3,int msgsend( int msqid, const void *ptr, size_t nbytes, int flag )

将数据放到队列中

4,ssize_t msgrcv( int msqid, void *ptr, size_t nbytes, long type, int flag )

从队列中取消息


示例程序:

#include<sys/msg.h>
#include<sys/ipc.h>
#include<sys/types.h>
#include<unistd.h>
#include<stdio.h>
#include<string.h>

struct msg_buf
{
    long mtype;
    char mtext[512];
};

int main( int argc, char **argv )
{
    key_t key;
    int id;
    int pid;
    struct msg_buf  meg;
   
    meg.mtype = getpid();
    key = ftok( argv[1], 1 );// ftok第一个形参必须引用一个现存文件
    if( (id=msgget(key, IPC_CREAT | 0666)) == -1 )
    {
        printf( "message get error\n" );
        exit( 0 );
    }
    if( pid=fork() )
    {
        strcpy( meg.mtext, argv[2] );
        if( msgsnd(id, &meg, sizeof(meg.mtext), IPC_NOWAIT) == -1 )//IPC_NOWAIT,类似IO非阻塞标识
        {
            printf( "message send error\n" );
            exit( 0 );
        }
        wait( pid );
        exit( 1 );
    }
    else
    {
        sleep( 1 );
        if( msgrcv(id, &meg, sizeof(meg.mtext), meg.mtype, MSG_NOERROR | IPC_NOWAIT) == -1 )
        {
            printf( "receieve error\n" );
            exit( 0 );
        }
        printf( "%s\n", meg.mtext );
        exit( 1 );
    }

}

你可能感兴趣的:(消息队列)