chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Linux下進(jìn)程通訊消息隊列

嵌入式技術(shù) ? 來源:嵌入式技術(shù) ? 作者:嵌入式技術(shù) ? 2022-08-19 19:56 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

Linux下進(jìn)程通訊消息隊列

?MQ(message queue),從字面意思上看,本質(zhì)是個隊列,F(xiàn)IFO 先入先出,只不過隊列中存放的內(nèi)容是message 而已。MQ 是在消息的傳輸過程中保存消息的容器。多用于分布式系統(tǒng)之間進(jìn)行通信。

消息隊列與 FIFO 很相似,都是一個隊列結(jié)構(gòu),都可以有多個進(jìn)程往隊列里面寫信息,多個進(jìn)程從隊列中讀取信息。

1.查看消息隊列命令

??1.查看消息隊列:ipcs -q

[wbyq@wbyq ~]$ ipcs -q

--------- 消息隊列 -----------
鍵        msqid      擁有者  權(quán)限     已用字節(jié)數(shù) 消息      
0xb8104ad9 1          wbyq       644        0            0           
0xd2350093 2          wbyq       666        208          2  

??2.查看消息隊列限制信息:ipcs -lq

[wbyq@wbyq ~]$ ipcs -lq

---------- 消息限制 -----------
系統(tǒng)最大隊列數(shù)量 = 32000
最大消息尺寸 (字節(jié)) = 8192
默認(rèn)的隊列最大尺寸 (字節(jié)) = 16384

??3.查看消息隊列詳細(xì)信息:ipcs -q -i

[wbyq@wbyq ~]$ ipcs -q -i 2

消息隊列 msqid=2
uid=1000	gid=1000	cuid=1000	cgid=1000	模式=0666
cbytes=208	qbytes=16384	qnum=2	lspid=10177	lrpid=10175
發(fā)送時間=Thu Apr 28 11:56:08 2022  
接收時間=Thu Apr 28 11:56:08 2022  
更改時間=Thu Apr 28 11:49:04 2022  

??4.創(chuàng)建消息隊列:ipcmk -Q

[wbyq@wbyq ~]$ ipcmk -Q
消息隊列 id:4
[wbyq@wbyq ~]$ ipcs -q

--------- 消息隊列 -----------
鍵        msqid      擁有者  權(quán)限     已用字節(jié)數(shù) 消息      
0xb8104ad9 1          wbyq       644        0            0           
0xd2350093 2          wbyq       666        208          2           
0x05ae2c01 4          wbyq       644        0            0        

5.刪除信號量:ipcrm -q

[wbyq@wbyq ~]$ ipcrm -q 4
[wbyq@wbyq ~]$ ipcs -q
--------- 消息隊列 -----------
鍵        msqid      擁有者  權(quán)限     已用字節(jié)數(shù) 消息      
0xb8104ad9 1          wbyq       644        0            0           
0xd2350093 2          wbyq       666        208          2    

2.相關(guān)函數(shù)

#include 
#include 
#include 
int msgget(key_t key, int msgflg);
函數(shù)功能:創(chuàng)建消息隊列
形參:key 鍵值,ftok產(chǎn)生
? ? ?msgflg?標(biāo)志 IPC_CREAT|0666
返回值:失敗返回-1,成功返回msqid
int msgsnd(int msqid, const void *msgp, size_t msgsz, int msgflg);
函數(shù)功能: 將消息添加到隊列中
形參:msqid msgget函數(shù)返回值
???msgp 消息內(nèi)容數(shù)據(jù),一般以結(jié)構(gòu)體類型填充
??????struct msgbuf {
????????????long mtype; /* 消息類型, 必須 > 0 */
????????????char mtext[1]; /消息數(shù)據(jù)/
????????????};
??????注意:struct msgbuf必須自己重寫,第一個參數(shù)long mtype必須指定,且>0,其他類型自定義
???msgsz 消息字節(jié)數(shù),大小為:sizeof(struct msgbuf)-sizeof(mtype);
???msgflg 0當(dāng)隊列滿時阻塞,直到消息寫入成功
??????IPC_NOWAIT 當(dāng)隊列滿時不阻塞,立刻返回
??????IPC_NOERROR 若發(fā)送的消息大于 size 字節(jié),則把該消息截斷,截斷部分將被丟棄,且不通知發(fā)送進(jìn)程。
返回值:成功返回0,失敗返回-1;
ssize_t msgrcv(int msqid, void *msgp, size_t msgsz, long msgtyp,int msgflg);
函數(shù)功能:從隊列中取出消息
形參:msqid msgget函數(shù)返回值
???msgp 存放讀取到的消息內(nèi)容
???msgsz 消息字節(jié)數(shù),大小為:sizeof(struct msgbuf)-sizeof(mtype);
???msgtyp 消息類型:
???????>0 接收對列中的第 1 個類型等于 msgtyp 的消息
???????==0 取出消息隊列中的第一條消息
???????<0 接收其類型小于或等于 msgtyp 絕對值的第 1 個最低類型消息
???msgflg 0 當(dāng)隊列空時阻塞,或者消息類型不匹配時阻塞
?????? IPC_NOWAIT 不阻塞,立刻返回
?????? IPC_NOERROR 若發(fā)送的消息大于 size 字節(jié),則把該消息截斷,截斷部分將被丟棄,且不通知發(fā)送進(jìn)程。
返回值:成功返回讀取的字節(jié)數(shù),失敗返回-1;
int msgctl(int msqid, int cmd, struct msqid_ds *buf);
函數(shù)功能:控制函數(shù)
形參:msqid msgget函數(shù)返回值
???cmd 通常為 IPC_RMID 表示刪除消息隊列。
當(dāng)刪除消息隊列時,則buf填NULL即可;

3.示例

??(1)創(chuàng)建消息隊列,添加消息到隊列

#include 
#include 
#include 
#include 
#include 
#include 
#include 
struct msgbuf
{
	long mtype;//消息類型,必須>0
	int cnt;
	char buff[100];
};
int main(int argc,char *argv[])
{
	if(argc!=4)
	{
		printf("格式:./app <消息類型> <消息數(shù)據(jù)> <消息內(nèi)容>\n");
		return 0;
	}
    key_t key=ftok("msgsnd.c", 1234);//生成鍵值
	if(key==-1)
	{
		printf("生成鍵值失敗err=%s\n",strerror(errno));
		return 0;
	}
	printf("key=%#x\n",key);
	int msqid=msgget(key,IPC_CREAT|0666);//創(chuàng)建消息隊列
	if(msqid==-1)
	{
		printf("創(chuàng)建消息隊列失敗err=%s\n",strerror(errno));
		return 0;
	}
	printf("msqid=%d\n",msqid);
	struct msgbuf msg;
	msg.mtype=atoi(argv[1]);//消息類型
	msg.cnt=atoi(argv[2]);//消息數(shù)據(jù)
	strcpy(msg.buff,argv[3]);//消息內(nèi)容
	int msg_size=sizeof(msg)-sizeof(long);//消息大小,總大小-消息類型大小
	/*添加消息到隊列*/
	int size=msgsnd(msqid,&msg,msg_size,0);
	if(size==-1)
	{
		printf("寫入消息失敗err=%s\n",strerror(errno));
	}
	else printf("消息寫入成功\n");
	return 0;
}  

??(2)從隊列中取消息

#include 
#include 
#include 
#include 
#include 
#include 
#include 
struct msgbuf
{
	long mtype;//消息類型,必須>0
	int cnt;
	char buff[100];
};
int main(int argc,char *argv[])
{
	if(argc!=2)
	{
		printf("格式:./app <消息類型>\n");
		return 0;
	}
    key_t key=ftok("msgsnd.c", 1234);//生成鍵值
	if(key==-1)
	{
		printf("生成鍵值失敗err=%s\n",strerror(errno));
		return 0;
	}
	printf("key=%#x\n",key);
	int msqid=msgget(key,IPC_CREAT|0666);//創(chuàng)建消息隊列
	if(msqid==-1)
	{
		printf("創(chuàng)建消息隊列失敗err=%s\n",strerror(errno));
		return 0;
	}
	printf("msqid=%d\n",msqid);
	struct msgbuf msg;
	int msg_size=sizeof(msg)-sizeof(long);//消息大小
	long msgtyp=atoi(argv[1]);//要寫讀取的消息類型
	//從消息隊列中取數(shù)據(jù)
	ssize_t size=msgrcv(msqid,&msg,msg_size,msgtyp,0);
	if(size==-1)
	{
		printf("讀取消息失敗err=%s\n",strerror(errno));
	}
	else 
	{
		printf("------------讀取消息成功size:%ld----------------\n",size);
		printf("\tmtype=%ld\n",msg.mtype);
		printf("\tcnt=%d\n",msg.cnt);
		printf("\tbuff=%s\n",msg.buff);
	}
	return 0;
}  

??(3)運行效果

pYYBAGL_eXuABxWmAAeJ5O7XsAY981.png#pic_center


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11511

    瀏覽量

    213781
  • IPC
    IPC
    +關(guān)注

    關(guān)注

    3

    文章

    366

    瀏覽量

    53169
  • 進(jìn)程
    +關(guān)注

    關(guān)注

    0

    文章

    207

    瀏覽量

    14280
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    RabbitMQ消息隊列解決方案

    在現(xiàn)代分布式系統(tǒng)架構(gòu)中,消息隊列作為核心組件,承擔(dān)著系統(tǒng)解耦、異步處理、流量削峰等重要職責(zé)。RabbitMQ作為一款成熟的消息隊列中間件,以其高可用性、高可靠性和豐富的特性,成為眾多企業(yè)的首選方案。本文將從運維工程師的角度,詳細(xì)闡述RabbitMQ從單機部署到集群搭建的完
    的頭像 發(fā)表于 07-08 15:55 ?183次閱讀

    NVME控制器之隊列管理模塊

    隊列管理模塊是整個NVMe Host控制器的核心模塊,該模塊實現(xiàn)了提交隊列與完成隊列的管理,多隊列請求的仲裁判決等功能。隊列管理模塊中含有數(shù)
    的頭像 發(fā)表于 05-03 15:32 ?189次閱讀
    NVME控制器之<b class='flag-5'>隊列</b>管理模塊

    Linux后臺進(jìn)程管理詳解

    當(dāng)我們在終端或控制臺工作時,可能不希望由于運行一個作業(yè)而占住了屏幕,因為可能還有更重要的事情要做,比如閱讀電子郵件。對于密集訪問磁盤的進(jìn)程,我們更希望它能夠在每天的非負(fù)荷高峰時間段運行(例如凌晨)。為了使這些進(jìn)程能夠在后臺運行,也就是說不在終端屏幕上運行,有幾種選擇方法可
    的頭像 發(fā)表于 04-25 11:04 ?414次閱讀
    <b class='flag-5'>Linux</b>后臺<b class='flag-5'>進(jìn)程</b>管理詳解

    Linux系統(tǒng)進(jìn)程管理入門指南

    Linux 系統(tǒng)中,進(jìn)程是正在運行的程序的實例。理解進(jìn)程的管理、查看和控制對于系統(tǒng)管理員和開發(fā)者來說非常重要
    的頭像 發(fā)表于 04-22 14:34 ?393次閱讀
    <b class='flag-5'>Linux</b>系統(tǒng)<b class='flag-5'>進(jìn)程</b>管理入門指南

    LinuxVim編輯器的使用技巧

    【Vim】常用總結(jié)? 簡介? image 什么是vim?? Linux兩大編輯神器之一 vim ? Linux/Unix使用最多的編輯器 ? vi的改進(jìn)版 ? 可能是最難上手的編輯
    的頭像 發(fā)表于 04-01 17:36 ?557次閱讀
    <b class='flag-5'>Linux</b><b class='flag-5'>下</b>Vim編輯器的使用技巧

    Linux進(jìn)程狀態(tài)詳解

    進(jìn)程狀態(tài)是task_struct內(nèi)的一個整數(shù);進(jìn)行:進(jìn)程在調(diào)度隊列中,進(jìn)程的狀態(tài)都是running,阻塞:等待某種設(shè)備或者資源就緒。進(jìn)程是一
    的頭像 發(fā)表于 04-01 09:46 ?437次閱讀
    <b class='flag-5'>Linux</b><b class='flag-5'>進(jìn)程</b>狀態(tài)詳解

    Linux計劃任務(wù)cron詳解

    cron是linux用來周期性的執(zhí)行某種任務(wù)或等待處理某些事件的一個守護(hù)進(jìn)程,與windows的計劃任務(wù)類似,當(dāng)安裝完成操作系統(tǒng)后,默認(rèn)會安裝此服務(wù) 工具,并且會自動啟動crond
    的頭像 發(fā)表于 02-07 15:31 ?977次閱讀
    <b class='flag-5'>Linux</b>計劃任務(wù)cron詳解

    深入解析Linux程序與進(jìn)程

    什么是程序 一組計算機能識別和執(zhí)行的指令,用于指導(dǎo)計算機執(zhí)行特定任務(wù)或解決特定問題。程序通常由代碼、數(shù)據(jù)和資源文件組成,涉及語法、算法和數(shù)據(jù)結(jié)構(gòu)。為二進(jìn)制文件 什么是進(jìn)程 是一個具有獨立功能的程序
    的頭像 發(fā)表于 12-18 11:01 ?479次閱讀
    深入解析<b class='flag-5'>Linux</b>程序與<b class='flag-5'>進(jìn)程</b>

    JavaWeb消息隊列使用指南

    用程序的通信方法,允許異步傳輸消息,并且具有存儲和轉(zhuǎn)發(fā)消息的能力。它主要解決以下問題: 異步處理 :允許系統(tǒng)組件異步處理任務(wù),提高響應(yīng)速度。 解耦系統(tǒng) :不同系統(tǒng)組件之間通過消息隊列通信,降低耦合度。 流量削峰 :在高流量情況,消息
    的頭像 發(fā)表于 11-25 09:27 ?523次閱讀

    深入Linux進(jìn)程管理:提升效率與穩(wěn)定性的關(guān)鍵方法

    目錄 Linux進(jìn)程管理 8.1 IO負(fù)載 8.2 實時進(jìn)程監(jiān)控 5.1 作業(yè)與會話 5.2 作業(yè)分類 4.1 ps 4.2pstree 4.3pgrep 4.4pidof 4.5 vmstat
    的頭像 發(fā)表于 11-22 11:05 ?782次閱讀
    深入<b class='flag-5'>Linux</b><b class='flag-5'>進(jìn)程</b>管理:提升效率與穩(wěn)定性的關(guān)鍵方法

    一文搞懂Linux進(jìn)程的睡眠和喚醒

    ): 進(jìn)程在等待某個條件滿足(如I/O操作),可以被信號喚醒。 Linux通過內(nèi)核提供的系統(tǒng)調(diào)用來控制進(jìn)程的睡眠。常用的系統(tǒng)調(diào)用有: sleep(): 使進(jìn)程暫停指定的秒數(shù)。 usl
    發(fā)表于 11-04 15:15

    Linux用戶身份與進(jìn)程權(quán)限詳解

    在學(xué)習(xí) Linux 系統(tǒng)權(quán)限相關(guān)的主題時,我們首先關(guān)注的基本都是文件的 ugo 權(quán)限。ugo 權(quán)限信息是文件的屬性,它指明了用戶與文件之間的關(guān)系。但是真正操作文件的卻是進(jìn)程,也就是說用戶所擁有的文件
    的頭像 發(fā)表于 10-23 11:41 ?765次閱讀
    <b class='flag-5'>Linux</b>用戶身份與<b class='flag-5'>進(jìn)程</b>權(quán)限詳解

    嵌入式環(huán)形隊列與消息隊列的實現(xiàn)原理

    嵌入式環(huán)形隊列,也稱為環(huán)形緩沖區(qū)或循環(huán)隊列,是一種先進(jìn)先出(FIFO)的數(shù)據(jù)結(jié)構(gòu),用于在固定大小的存儲區(qū)域中高效地存儲和訪問數(shù)據(jù)。其主要特點包括固定大小的數(shù)組和兩個指針(頭指針和尾指針),分別指向隊列的起始位置和結(jié)束位置。
    的頭像 發(fā)表于 09-02 15:29 ?1252次閱讀

    深入探討Linux進(jìn)程調(diào)度器

    Linux操作系統(tǒng)作為一個開源且廣泛應(yīng)用的操作系統(tǒng),其內(nèi)核設(shè)計包含了許多核心功能,而進(jìn)程調(diào)度器(Scheduler)就是其中一個至關(guān)重要的模塊。進(jìn)程調(diào)度器負(fù)責(zé)決定在任何給定的時刻哪個進(jìn)程
    的頭像 發(fā)表于 08-13 13:36 ?1288次閱讀
    深入探討<b class='flag-5'>Linux</b>的<b class='flag-5'>進(jìn)程</b>調(diào)度器

    玩轉(zhuǎn)RT-Thread之消息隊列的應(yīng)用

    在嵌入式系統(tǒng)開發(fā)中,實時處理串口和ADC數(shù)據(jù)是一項重要的任務(wù)。本文將介紹如何在RT-Thread實時操作系統(tǒng)中,利用消息隊列來同時處理來自串口和ADC的數(shù)據(jù)。通過這種方法,我們能夠高效地管理和處理
    的頭像 發(fā)表于 07-23 08:11 ?910次閱讀
    玩轉(zhuǎn)RT-Thread之消息<b class='flag-5'>隊列</b>的應(yīng)用