IT培训机构|91免费精品视频|专注编程培训|91免费精品|软件开发培训_91免费国产视频_华清远见教育


linux 消息隊列

分享到:
           

    本文關鍵字: 消息隊列,linux 消息隊列

    顧名思義,消息隊列就是一些消息的列表,用戶可以在消息隊列中添加消息和讀取消息等。從這點上看,消息隊列具有一定的FIFO特性,但是它可以實現消息的隨機查詢,比FIFO具有更大的優勢。同時,這些消息又是存在于內核中的,由“隊列ID”來標識。

    消息隊列的實現包括創建或打開消息隊列、添加消息、讀取消息和控制消息隊列4種操作,其中創建或打開消息隊列使用的函數是msgget(),這里創建的消息隊列的數量會受到系統消息隊列數量的限制;添加消息使用的函數是msgsnd(),它把消息添加到已打開的消息隊列末尾;讀取消息使用的函數是msgrcv(),它把消息從消息隊列中取走,與FIFO不同的是,這里可以取走指定的某一條消息;控制消息隊列使用的函數是msgctl(),它可以完成多項功能。

    表1列舉了msgget()函數的語法要點。

表1 msgget()函數語法要點

所需頭文件 #include <sys/types.h>
#include <sys/ipc.h>
#include <sys/shm.h>
函數原型 int msgget(key_t key, int msgflg)
函數傳入值 key:消息隊列的鍵值,多個進程可以通過它訪問同一個消息隊列,其中有個特殊值IPC_PRIVATE,用于創建當前進程的私有消息隊列
msgflg:權限標志位
函數返回值 成功:消息隊列ID
出錯:-1

    表2列舉了msgsnd()函數的語法要點。

表2 msgsnd()函數語法要點

所需頭文件 #include <sys/types.h>
#include <sys/ipc.h>
#include <sys/shm.h>
函數原型 int msgsnd(int msqid, const void *msgp, size_t msgsz, int msgflg)
函數傳入值 msqid:消息隊列的隊列ID
msgp:指向消息結構的指針,該消息結構msgbuf通常如下。
struct msgbuf
{
  long mtype; /* 消息類型,該結構必須從這個域開始 */
  char mtext[1]; /* 消息正文 */
}
msgsz:消息正文的字節數(不包括消息類型指針變量)
msgflg IPC_NOWAIT:若消息無法立即發送(如當前消息隊列已滿),函數會立即返回
0:msgsnd調用阻塞直到發送成功為止
函數返回值 成功:0
出錯:-1

    表3列舉了msgrcv()函數的語法要點。

表3 msgrcv()函數語法要點

所需頭文件 #include <sys/types.h>
#include <sys/ipc.h>
#include <sys/shm.h>
函數原型 int msgrcv(int msgid, void *msgp, size_t msgsz, long int msgtyp, int msgflg)
函數傳入值 msqid:消息隊列的隊列ID
msgp:消息緩沖區,同msgsnd()函數的msgp
msgsz:消息正文的字節數(不包括消息類型指針變量)
msgtyp 0:接收消息隊列中第一個消息
大于0:接收消息隊列中第一個類型為msgtyp的消息
函數傳入值 小于0:接收消息隊列中第一個類型值不小于msgtyp絕對值且類型值小的消息
msgflg MSG_NOERROR:若返回的消息比msgsz字節多,則消息就會截短到msgsz字節,且不通知消息發送進程
IPC_NOWAIT:若在消息隊列中并沒有相應類型的消息可以接收,則函數立即返回
0:msgsnd()調用阻塞直到接收一條相應類型的消息為止
函數返回值 成功:0
出錯:-1

    表4列舉了msgctl()函數的語法要點。

表4 msgctl()函數語法要點

所需頭文件 #include <sys/types.h>
#include <sys/ipc.h>
#include <sys/shm.h>
函數原型 int msgctl (int msgqid, int cmd, struct msqid_ds *buf )
函數傳入值 msqid:消息隊列的隊列ID
cmd:命令參數 IPC_STAT:讀取消息隊列的數據結構msqid_ds,并將其存儲在buf指定的地址中
IPC_SET:設置消息隊列的數據結構msqid_ds中的ipc_perm域(IPC操作權限描述結構)值,這個值取自buf參數
IPC_RMID:從系統內核中刪除消息隊列
buf:描述消息隊列的msqid_ds結構類型變量
函數返回值 成功:0
出錯:-1

    下面的實例體現了如何使用消息隊列進行兩個進程(發送端和接收端)之間的通信,包括消息隊列的創建、消息發送與讀取、消息隊列的撤銷和刪除等多種操作。

    消息發送端進程和消息接收端進程間不需要額外實現進程間的同步。在該實例中,發送端發送的消息類型設置為該進程的進程號(可以取其他值),因此接收端根據消息類型來確定消息發送者的進程號。注意這里使用了fotk()函數,它可以根據不同的路徑和關鍵字產生標準的key。消息隊列發送端的代碼如下:

    /* msgsnd.c */
    #include <sys/types.h>
    #include <sys/ipc.h>
    #include <sys/msg.h>
    #include <stdio.h>
    #include <stdlib.h>
    #include <unistd.h>
    #include <string.h>
    #define BUFFER_SIZE 512


    struct message
    {
        long msg_type;
        char msg_text[BUFFER_SIZE];
    };
    int main()
    {
        int qid;
        key_t key;
        struct message msg;

        /* 根據不同的路徑和關鍵字產生標準的key */
        if ((key = ftok(".", 'a')) == -1)
        {
            perror("ftok");
            exit(1);
        }
        /* 創建消息隊列 */
        if ((qid = msgget(key, IPC_CREAT|0666)) == -1)
        {
            perror("msgget");
            exit(1);
        }
        printf("Open queue %d\n",qid);
        while(1)
        {
            printf("Enter some message to the queue:");
            if ((fgets(msg.msg_text, BUFFER_SIZE, stdin)) == NULL)
            {
                puts("no message");
                exit(1);
            }

            msg.msg_type = getpid();
            /* 添加消息到消息隊列 */
            if ((msgsnd(qid, &msg, strlen(msg.msg_text), 0)) < 0)
            {
                perror("message posted");
                exit(1);
            }
            if (strncmp(msg.msg_text, "quit", 4) == 0)
            {
                break;
            }
        }
        exit(0);
    }

    消息隊列接收端的代碼如下:

    /* msgrcv.c */
    #include <sys/types.h>
    #include <sys/ipc.h>
    #include <sys/msg.h>
    #include <stdio.h>
    #include <stdlib.h>
    #include <unistd.h>
    #include <string.h>
    #define BUFFER_SIZE 512

    struct message
    {
        long msg_type;
        char msg_text[BUFFER_SIZE];
    };
    int main()
    {
        int qid;
        key_t key;
        struct message msg;

        /* 根據不同的路徑和關鍵字產生標準的key */
        if ((key = ftok(".", 'a')) == -1)
        {
            perror("ftok");
            exit(1);
        }
        /* 創建消息隊列 */
        if ((qid = msgget(key, IPC_CREAT|0666)) == -1)
        {
            perror("msgget");
            exit(1);
        }
        printf("Open queue %d\n", qid);
        do
        {
            /* 讀取消息隊列 */
            memset(msg.msg_text, 0, BUFFER_SIZE);
            if (msgrcv(qid, (void*)&msg, BUFFER_SIZE, 0, 0) < 0)
            {
                perror("msgrcv");
                exit(1);
            }
            printf("The message from process %d : %s", msg.msg_type, msg.msg_text);

        } while(strncmp(msg.msg_text, "quit", 4));
        /* 從系統內核中移走消息隊列 */
        if ((msgctl(qid, IPC_RMID, NULL)) < 0)
        {
            perror("msgctl");
            exit(1);
        }
        exit(0);
    }

    以下是程序的運行結果,輸入“quit”則兩個進程都將結束。

    $ ./msgsnd
    Open queue 327680
    Enter some message to the queue:first message
    Enter some message to the queue:second message
    Enter some message to the queue:quit
    $ ./msgrcv
    Open queue 327680
    The message from process 6072 : first message
    The message from process 6072 : second message
    The message from process 6072 : quit

    本文選自華清遠見嵌入式培訓教材《從實踐中學嵌入式Linux應用程序開發》

   熱點鏈接:

   1、linux 共享內存
   2、linux下的信號量
   3、linux下的信號處理實例
   4、信號處理函數signal()和信號集函數組
   5、信號捕捉函數alarm()和pause()

更多新聞>> 

主站蜘蛛池模板: 上海专升本-上海统招专升本网 | 深圳专卖店设计,餐饮空间设计,酒店空间策划设计【左右高端人文空间设计公司】 | 商城网站建设_商城系统_响应式商城_小程序商城_FwShop | 球磨机配件_烘干机配件_回转窑配件_球磨机小齿轮_球磨机大齿轮-巩义市兴农机械制造公司 | 塑胶篮球场施工|塑胶网球场施工|幼儿园塑胶施工|石家庄亚强体育公司 | 衡水一体化污水处理设备|循环水旁滤器|加药装置|钢厂浊环净化装置|河北欧意科技集团有限公司 | 聚达|聚达物联|聚达物联科技|杭州聚达物联科技有限公司|www.judawulian.com|智慧社区|数字驾驶舱|智慧清运|智慧工地|邻家小达 | 上海钧尚电器有限公司 - Faulhaber电机 AMETEK pittman电机 AMETEK ROTRON军用航空风机 Exlar电动缸 MAE电机 MCG电机 CP电动工具 马头工具 AMCI驱动器 直流电机 减速箱 直流伺服电机,无刷电机,直线电机 直流防爆电机 防爆电机 汽车助力转向电机 EPS电机 faulhaber motor faulhaber gearbox NANOTEC电机 ELWOOD电机 PHYTRON电机 EXLAR伺服电动缸 高力矩、高性能直流电机,音圈电机,风机,直流风机,航空风机 | 江苏工业双氧水_工业亚硝酸钠的作用与用途_工业双氧水厂家-江苏连云港嘉一化工厂 | 扬州华工电气有限公司|环氧树脂管|金刚石绝缘板|U型绝缘槽|电解槽绝缘材料 | 网带烘干机-不锈钢网带-乙型网带-不锈钢链板-网带输送机-宁津县天惠机械制造有限公司 | 山东淄博海杰化工有限公司-淄博海杰化工_NP-10、OP-10、吐温80、司盘80、磺酸、油酸等乳化剂 | 南京企业宣传片制作,广告形象片,影视制作,宣传片拍摄,微电影拍摄制作公司 | 球场地板_运动场地面_体育设施器材_地坪漆工程_项目承接-大上实业(深圳)有限公司 | 金属雕花板厂家_外墙保温板_专业生产批发_山东百菲特 | 山东岱新起重机械有限公司,单梁桥式起重机,双梁桥式起重机,通用式门式起重机,欧式起重机系列 | 实木中药柜,实木中药斗,木制中药柜,木制中药柜的价格,实木中草药柜,安国美佳中药柜厂家 | 思达测试|山东思达高科机械设备有限公司 | 模温机_厂家_现货供应-卡塞尔机械(浙江)有限公司 | 久久91精品久久91综合_国产亚洲自拍一区_国产精品第1页_亚洲高清视频一区_91成人午夜在线精品_亚洲国产精品网站在线播放_亚洲国产成人久久综合区_国产精品亚洲专区在线观看_免费视频精品一区二区三区 | 上海企业团建|上海团建|上海团建活动|上海拓展培训|上海拓展训练|傲朗企业管理顾问(上海)有限公司 | 喜有沃-河南不锈钢管厂家批发201,304不锈钢管-现货规格齐全 | 液晶拼接屏_三星46寸/55寸/LG液晶拼接屏_深圳拼接墙厂家_电视大屏幕液晶拼接_高清工业级液晶监视器 | 环保除尘设备_燃气/燃油热水锅炉_光氧空气净化器_蒸汽玉米压片机_压片设备_烘干设备-山东金盾节能环保设备有限公司 | 天津鸿宸机械设备有限公司-提取浓缩设备和生物制药设备以及制剂设备、粉碎设备、烘干等设备供应商 | 智能照明模块_智能照明控制器_照明控制系统_智能调光模块_西安邦华电气工程有限公司 | 消防工程公司,消防工程承接公司-亿杰(北京)工程安装有限公司 | 混凝土砂石分离机_龙门洗车机_振动型砂石分离机 - 青州同辉环保机械 | 逍遥安卓模拟器_安卓模拟器电脑版_安卓手游模拟器哪个好用_逍遥手机模拟器官网 | 耐磨焊条_高硬度堆焊焊条_碳化钨合金耐磨焊丝_北京耐默 | 停车场收费管理系统,通道闸系统,门禁系统,东莞停车场收费管理系统,东莞通道闸系统,-东莞市骄阳交通设备有限公司 | 山东向阳电子科技有限公司-多用户集中式电能表生产厂家,NB物联网水表,刷卡水电表生产厂家,泰安智能水电表价格 | 武汉印刷厂_为企业提供宣传单页彩页印刷_武汉折页印刷_海报设计印刷与制作 - 武汉泽雅印刷公司 | 网带窑,催化剂网带窑,电热回转窑-淄博圣元窑炉工程有限公司 | 五金冲压件生产厂家_加工五金拉伸件-沧州浚鼎机械制造有限公司-沧州浚鼎机械制造有限公司 | 重庆监控-监控系统-大型弱电工程-重庆万建电子工程有限责任公司是智能化一级工程公司 | 铅板-济南鑫玉防辐射材料有限公司 | 住友套管总代理-日本住友套管-住友热缩管-上海弘奇电子科技有限公司 | 友信京泰-操作台-调度台-控制台-监控台定制厂家 | 潍坊亿宏重工机械有限公司,破碎机,高性能立磨机,颚式破碎机,锤式破碎机反击式破碎机,重锤式破碎机,高性能反击式破碎机,圆锥式破碎机,给料机系列,链板给料机系列,简易给料机系列,振动给料机 | 集装箱零配件_不锈钢丝绳厂家_镀锌铁链条_合页非标件定制_上海英鑫多实业有限公司 |