欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Linux消息隊列實現(xiàn)進(jìn)程間通信實例詳解

 更新時間:2017年07月10日 10:26:28   作者:ChaseRaod  
這篇文章主要介紹了Linux消息隊列實現(xiàn)進(jìn)程間通信實例詳解的相關(guān)資料,需要的朋友可以參考下

Linux消息隊列實現(xiàn)進(jìn)程間通信實例詳解

一、什么是消息隊列

消息隊列提供了一種從一個進(jìn)程向另一個進(jìn)程發(fā)送一個數(shù)據(jù)塊的方法。  每個數(shù)據(jù)塊都被認(rèn)為含有一個類型,接收進(jìn)程可以獨(dú)立地接收含有不同類型的數(shù)據(jù)結(jié)構(gòu)。我們可以通過發(fā)送消息來避免命名管道的同步和阻塞問題。但是消息隊列與命名管道一樣,每個數(shù)據(jù)塊都有一個最大長度的限制。

Linux用宏MSGMAX和MSGMNB來限制一條消息的最大長度和一個隊列的最大長度。

二、在Linux中使用消息隊列

Linux提供了一系列消息隊列的函數(shù)接口來讓我們方便地使用它來實現(xiàn)進(jìn)程間的通信。它的用法與其他兩個System V PIC機(jī)制,即信號量和共享內(nèi)存相似。

進(jìn)程間通信(IPC):進(jìn)程間通信的本質(zhì)就是通過讓不同的進(jìn)程看到一份公共的資源來實現(xiàn)通信。

常用的進(jìn)程間通信的方式有兩種:通過管道和systemv標(biāo)準(zhǔn),今天我們來介紹systemv標(biāo)準(zhǔn)中的一種:消息隊列

消息隊列:消息隊列提供了一種從一個進(jìn)程向另一個進(jìn)程發(fā)送一個數(shù)據(jù)塊的方法,每個數(shù)據(jù)塊都認(rèn)為是有一個類型,接受者進(jìn)程接收的數(shù)據(jù)塊可以有不同的類型值。我們可以通過發(fā)送消息來避免命名管道的同步和阻塞問題。

特點(diǎn):

(1)消息隊列可認(rèn)為是全局的一個鏈表,由消息隊列標(biāo)識符進(jìn)行標(biāo)識。
(2)消息隊列允許一個或多個進(jìn)程寫入或讀取消息
(3)消息隊列的聲明周期隨內(nèi)核
(4)消息隊列可以實現(xiàn)雙向通信

創(chuàng)建一個消息隊列:msget()
這里寫圖片描述
第一個參數(shù):每一個消息隊列都有唯一的key值,可以由ftok()產(chǎn)生

第二個參數(shù):一般由兩個選項IPC_CREAT和IPC_EXCL,單獨(dú)使用ipc_creat時,如果消息隊列不存在則創(chuàng)建一個,如果存在則打開 IPC_EXCL 如果同時使用,如果消息隊列不存在則創(chuàng)建之,如果存在則出錯返回。當(dāng)單獨(dú)使用IPC_EXCL時,沒有意義。

ftok:
這里寫圖片描述
參數(shù)可由用戶指定。

下面用代碼實現(xiàn)消息隊列的創(chuàng)建:

在創(chuàng)建一個消息隊列(其他ipc相同)時,需要先通過文件路徑名和項目ID獲取一個鍵值,然后通過此鍵值由內(nèi)核生成標(biāo)識符,在以后可通過此標(biāo)識符來使用此消息隊列。
這里寫圖片描述

為什么要有key值和標(biāo)識符兩個值呢?

描述符是對于用戶操作而言的,讓用戶感覺操作和對文件的操作相同,key是對于系統(tǒng)內(nèi)部說的。

我們使用ftok來創(chuàng)建key值,具體可以man一下fotk函數(shù),大概是這樣的:按給定的路徑名取得其stat結(jié)構(gòu),從該結(jié)構(gòu)中取出部分st_dev和st_ino字段,然后再與項目id組合起來,如果兩個路徑名引用兩個不同的文件,那么,對這兩個路徑名調(diào)用ftok通常返回不同的key值,但是,因為i節(jié)點(diǎn)號和key通常都存放在長整型中,于是創(chuàng)建key時可能會丟失信息,這意味著,如果使用同一項目id,那么對于不同文件的兩個路徑名可能產(chǎn)生相同的key值。而標(biāo)識符是唯一確定的,可以用來區(qū)別于其他ipc的。

刪除消息隊列:msgctl()
這里寫圖片描述
代碼實現(xiàn):
這里寫圖片描述

發(fā)送消息:msgsnd()

接收消息:magrcv(),這兩個函數(shù)實現(xiàn)進(jìn)程間的雙向通信
這里寫圖片描述 

參數(shù):msqid-消息隊列標(biāo)識碼

msgp-指向消息緩沖區(qū)的指針,此位置是用來暫時存儲發(fā)送和接收的消息,是一個用戶可定義的通用結(jié)構(gòu)。
msgtyp-從消息隊列內(nèi)讀取的消息形態(tài)。如果值為0,則表示消息隊列中,所有消息被讀取。
msgsz:消息的大小

返回值:成功返回0,失敗則返回-1.
這里寫圖片描述

那么如何查看系統(tǒng)中正在運(yùn)行的消息隊列呢?

介紹兩個命令:ipcs -q 查看消息隊列

ipcrm -q msgid 刪除此消息隊列
這里寫圖片描述

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

相關(guān)文章

  • 5個Shell腳本編程入門練習(xí)例子

    5個Shell腳本編程入門練習(xí)例子

    這篇文章主要介紹了5個Shell腳本編程入門例子,涵蓋了各種操作,又有一些游戲的性質(zhì),作為入門練習(xí)例子是不很不錯的,需要的朋友可以參考下
    2014-06-06
  • Shell腳本中$符號的嵌套使用方法小結(jié)

    Shell腳本中$符號的嵌套使用方法小結(jié)

    在編寫Shell腳本時,通過嵌套使用$符號,間接獲取變量或表達(dá)式的值的具體方法,文中根據(jù)實例編碼詳細(xì)介紹的十分詳盡,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2023-05-05
  • 詳解shell中>/dev/null 2>&1到底是什么

    詳解shell中>/dev/null 2>&1到底是什么

    這篇文章主要介紹了shell中>/dev/null 2>&1到底是什么,文中介紹的很詳細(xì),需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-02-02
  • Shell+Linux命令實現(xiàn)日志分析

    Shell+Linux命令實現(xiàn)日志分析

    這篇文章主要介紹了Shell+Linux命令實現(xiàn)日志分析,本文給出了結(jié)合grep命令、awk命令等實現(xiàn)了幾個常用的日志分析統(tǒng)計長命令,需要的朋友可以參考下
    2014-08-08
  • Linux 編程之進(jìn)程fork()詳解及實例

    Linux 編程之進(jìn)程fork()詳解及實例

    這篇文章主要介紹了Linux 編程之進(jìn)程fork()詳解及實例的相關(guān)資料,需要的朋友可以參考下
    2017-03-03
  • Shell腳本檢查IP格式及mysql操作實例

    Shell腳本檢查IP格式及mysql操作實例

    這篇文章主要介紹了Shell腳本檢查IP格式及mysql操作實例,本文直接給出腳本代碼,需要的朋友可以參考下
    2015-05-05
  • shell中的for循環(huán)用法詳解

    shell中的for循環(huán)用法詳解

    這篇文章主要介紹了shell中的for循環(huán)用法詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-05-05
  • centos/rhel下實現(xiàn)nginx自啟動腳本實例

    centos/rhel下實現(xiàn)nginx自啟動腳本實例

    這篇文章主要介紹了centos/rhel下實現(xiàn)nginx自啟動腳本,需要的朋友可以參考下
    2014-07-07
  • shell 提取文件名和目錄名的方法實現(xiàn)

    shell 提取文件名和目錄名的方法實現(xiàn)

    本文主要介紹了shell 提取文件名和目錄名的方法實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-02-02
  • Linux shell知識點(diǎn)匯總

    Linux shell知識點(diǎn)匯總

    從程序員的角度來看, Shell本身是一種用C語言編寫的程序,從用戶的角度來看,Shell是用戶與Linux操作系統(tǒng)溝通的橋梁。用戶既可以輸入命令執(zhí)行,又可以利用 Shell腳本編程,完成更加復(fù)雜的操作。
    2015-08-08

最新評論