日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當前位置:首頁 > > 充電吧
[導讀]消息隊列是一個存放在內核中的消息鏈表,每個消息隊列由隊列標識符標識,與管道不同的是消息隊列是放在內核當中,只有在內核重啟,或者顯式的刪除一個消息隊列,該消息隊列才會被真正的刪除,以下會有幾個操作,1.

消息隊列是一個存放在內核中的消息鏈表,每個消息隊列由隊列標識符標識,與管道不同的是消息隊列是放在內核當中,只有在內核重啟,或者顯式的刪除一個消息隊列,該消息隊列才會被真正的刪除,以下會有幾個操作,

1.創(chuàng)建消息隊列

#include

#include

key_t ftok(const char* pathname,int proj_id);

根據傳入的參數的唯一性,創(chuàng)建一個消息隊列

int? msgget(key_t key,int msgflag);

該參數ley是即為ftok函數的返回值,mshflag是一個標識參數

IPC_CREATE:如果內核中不存在于key相等的消息隊列,則新建一個消息隊列

IPC_EXCL和IPC_CREATE一起使用,如果對應鍵值的消息對流已經存在,則出錯,返回-1

2.寫消息隊列

int msgsnd(int msgid,struct msgbuf* msgp,size_t msgz,int msgflag)

msgid是消息隊列的標識

msgp是發(fā)送的消息

msgz要發(fā)送的消息的大小

msgflag操作標識,當他是0的時候,當消息隊列已曼則,msgsnd則會阻塞,直到可以寫入,如果msgflag是

IPC_NOWAIT的時候,如果消息隊列已滿則,立即返回

3.讀消息隊列

int msgrcv(int msgid,struct msgbuf* msgp,size_t msglen,long msgtyp,int msgflag);

現(xiàn)在源代碼如下

msg_server.c


/*
?*?main.cpp
?*
?*??Created?on:?Jul?18,?2014
?*??????Author:?john
?*/

#include#include#include#include#include#include#include#include#include#include#include#define?BUF_SIZE?256
#define?PROJ_ID??32
#define?PATH_NAME?"/tmp"
#define?SERVER_MSG??1
#define?CLIENT_MSG?2
using?namespace?std;



int?main()
{
???struct?mymsg
???{
?????long?msgtype;
?????char?content[256];
???}msgbuf;
???
??//?var?define
???int?qid;//消息隊列標識
????int?msglen;//消息長度
???key_t?msgkey;
?
??//獲取鍵值
??msgkey=ftok(PATH_NAME,PROJ_ID);
??if(msgkey==-1)
???{
?????cout<<"sorry?key?create?failed:?"<<strerror(errno)<<endl;
?????exit(0);???
??}
??//獲取消息隊列
??cout<<"創(chuàng)建鍵值成功n";
??
??qid=msgget(msgkey,IPC_CREAT|0666);
??if(qid==-1)
???{
??????cout<<"get?msg?quen?failed?"<<strerror(errno)<<endl;
??????exit(0);
???}
??cout<<"獲取消息隊列成功"<<qid<<"n";
??//開始讀取和寫入消息
??while(1)
??{
?????cout<>msgbuf.content;
?????if(strncmp(msgbuf.content,"exit",4)==0)
?????{
????	?//獲取消息屬性,IPC——RMID從內核中刪除qid的消息隊列
?????????msgctl(qid,IPC_RMID,NULL);
?????????exit(0);
?????}
?????msgbuf.msgtype=SERVER_MSG;
??????if(?msgsnd(qid,&msgbuf,strlen(msgbuf.content)+1,0)==-1)
?????{
??????????cout<<"msg?send?failed"<<endl;
??????????exit(1);
?????}
??????cout<<"正在接收客戶端的消息n";
?????if(msgrcv(qid,&msgbuf,BUF_SIZE,CLIENT_MSG,0)==-1)
?????{
?????????cout<<"msg?rcv?failed"<<endl;
?????????exit(0);
?????}
?????cout<<"Client:?"<<msgbuf.content<<endl;
?????
??}
}


msg_client.c文件如下:


/*
?*?main.cpp
?*
?*??Created?on:?Jul?18,?2014
?*??????Author:?john
?*/

#include#include#include#include#include#include#include#include#include#include#include#define?BUF_SIZE?256
#define?PROJ_ID??32
#define?PATH_NAME?"/tmp"
#define?SERVER_MSG??1
#define?CLIENT_MSG?2
using?namespace?std;



int?main()
{
???struct?mymsg
???{
?????long?msgtype;
?????char?content[256];
???}msgbuf;

??//?var?define
???int?qid;//消息隊列標識
????int?msglen;//消息長度
???key_t?msgkey;

??//獲取鍵值
??msgkey=ftok(PATH_NAME,PROJ_ID);
??if(msgkey==-1)
???{
?????cout<<"sorry?key?create?failed:?"<<strerror(errno)<<endl;
?????exit(0);
??}
??cout<<"獲取鍵值成功n";
??//獲取消息隊列

??qid=msgget(msgkey,IPC_CREAT|0666);
??if(qid==-1)
???{
??????cout<<"get?msg?quen?failed?"<<strerror(errno)<<endl;
??????exit(0);
???}
??cout<<"獲取消息隊列成功"<<qid<<"n";
??//開始讀取和寫入消息
??while(1)
??{
	??cout<<"正在接收服務器給客戶段的消息n";
	??if(msgrcv(qid,&msgbuf,BUF_SIZE,SERVER_MSG,0)==-1)
	??????{
	??????????cout<<"msg?rcv?failed"<<endl;
	??????????exit(0);
	??????}
	??????cout<<"Server:?"<<msgbuf.content<<endl;
?????cout<>msgbuf.content;
?????if(strncmp(msgbuf.content,"exit",4)==0)
?????{
????	?//獲取消息屬性,IPC——RMID從內核中刪除qid的消息隊列
?????????msgctl(qid,IPC_RMID,NULL);
?????????exit(0);
?????}
?????msgbuf.msgtype=CLIENT_MSG;
??????if(?msgsnd(qid,&msgbuf,strlen(msgbuf.content)+1,0)==-1)
?????{
??????????cout<<"msg?send?failed"<<endl;
??????????exit(1);
?????}
??}
}

唯一需要注意的是,在msgrcv的參數中要寫入需要接收的消息的類型。

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

CPU親和度通過限制進程或線程可以運行的CPU核心集合,使得它們只能在指定的CPU核心上執(zhí)行。這可以減少CPU緩存的失效次數,提高緩存命中率,從而提升系統(tǒng)性能。

關鍵字: Linux 嵌入式

在機器對機器(M2M)通信場景中,消息隊列作為系統(tǒng)解耦的核心組件,通過異步傳輸機制提升系統(tǒng)吞吐量與容錯能力。而服務質量(QoS)保障機制則是確保消息可靠傳遞的關鍵技術,不同協(xié)議針對物聯(lián)網場景的特性設計了差異化的實現(xiàn)方案。...

關鍵字: M2M 消息隊列

在Linux系統(tǒng)性能優(yōu)化中,內存管理與網絡連接處理是兩大核心領域。vm.swappiness與net.core.somaxconn作為關鍵內核參數,直接影響系統(tǒng)在高負載場景下的穩(wěn)定性與響應速度。本文通過實戰(zhàn)案例解析這兩個...

關鍵字: Linux 內存管理

對于LLM,我使用b谷歌Gemini的免費層,所以唯一的成本是n8n托管。在使用了n8n Cloud的免費積分后,我決定將其托管在Railway上(5美元/月)。然而,由于n8n是開源的,您可以在自己的服務器上托管它,而...

關鍵字: 人工智能 n8n Linux

在Linux系統(tǒng)管理中,權限控制是安全運維的核心。本文通過解析/etc/sudoers文件配置與組策略的深度應用,結合某金融企業(yè)生產環(huán)境案例(成功攔截98.7%的非法提權嘗試),揭示精細化權限管理的關鍵技術點,包括命令別...

關鍵字: Linux 用戶權限 sudoers文件

Linux內核中的信號量(Semaphore)是一種用于資源管理的同步原語,它允許多個進程或線程對共享資源進行訪問控制。信號量的主要作用是限制對共享資源的并發(fā)訪問數量,從而防止系統(tǒng)過載和數據不一致的問題。

關鍵字: Linux 嵌入式

在云計算與容器化技術蓬勃發(fā)展的今天,Linux網絡命名空間(Network Namespace)已成為構建輕量級虛擬網絡的核心組件。某頭部互聯(lián)網企業(yè)通過命名空間技術將測試環(huán)境資源消耗降低75%,故障隔離效率提升90%。本...

關鍵字: Linux 云計算

在Linux內核4.18+和主流發(fā)行版(RHEL 8/Ubuntu 20.04+)全面轉向nftables的背景下,某電商平臺通過遷移將防火墻規(guī)則處理效率提升40%,延遲降低65%。本文基于真實生產環(huán)境案例,詳解從ipt...

關鍵字: nftables Linux

在Linux設備驅動開發(fā)中,等待隊列(Wait Queue)是實現(xiàn)進程睡眠與喚醒的核心機制,它允許進程在資源不可用時主動放棄CPU,進入可中斷睡眠狀態(tài),待資源就緒后再被喚醒。本文通過C語言模型解析等待隊列的實現(xiàn)原理,結合...

關鍵字: 驅動開發(fā) C語言 Linux

在Unix/Linux進程間通信中,管道(pipe)因其簡單高效被廣泛使用,但默認的半雙工特性和無同步機制容易導致數據競爭。本文通過父子進程雙向通信案例,深入分析互斥鎖與狀態(tài)機在管道同步中的應用,實現(xiàn)100%可靠的數據傳...

關鍵字: 管道通信 父子進程 Linux
關閉