這篇文章主要介紹如何實(shí)現(xiàn)進(jìn)程間通信,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!
成都創(chuàng)新互聯(lián)是一家專注于成都做網(wǎng)站、網(wǎng)站制作與策劃設(shè)計(jì),定日網(wǎng)站建設(shè)哪家好?成都創(chuàng)新互聯(lián)做網(wǎng)站,專注于網(wǎng)站建設(shè)10年,網(wǎng)設(shè)計(jì)領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:定日等地區(qū)。定日做網(wǎng)站價(jià)格咨詢:18982081108進(jìn)程間通信的方式有:1、管道通常指無(wú)名管道,是UNIX系統(tǒng)IPC最古老的形式;2、FIFO,是一種文件類型;3、消息隊(duì)列,是消息的鏈接表,存放在內(nèi)核中;4、信號(hào)量,是一個(gè)計(jì)數(shù)器;5、共享內(nèi)存。
進(jìn)程間通信的方式有:
一、管道
管道,通常指無(wú)名管道,是 UNIX 系統(tǒng)IPC最古老的形式。
特點(diǎn):
它是半雙工的(即數(shù)據(jù)只能在一個(gè)方向上流動(dòng)),具有固定的讀端和寫(xiě)端。
它只能用于具有親緣關(guān)系的進(jìn)程之間的通信(也是父子進(jìn)程或者兄弟進(jìn)程之間)。
它可以看成是一種特殊的文件,對(duì)于它的讀寫(xiě)也可以使用普通的read、write 等函數(shù)。但是它不是普通的文件,并不屬于其他任何文件系統(tǒng),并且只存在于內(nèi)存中。
二、FIFO
FIFO,也稱為命名管道,它是一種文件類型。
1、特點(diǎn)
FIFO可以在無(wú)關(guān)的進(jìn)程之間交換數(shù)據(jù),與無(wú)名管道不同。
FIFO有路徑名與之相關(guān)聯(lián),它以一種特殊設(shè)備文件形式存在于文件系統(tǒng)中。
三、消息隊(duì)列
消息隊(duì)列,是消息的鏈接表,存放在內(nèi)核中。一個(gè)消息隊(duì)列由一個(gè)標(biāo)識(shí)符(即隊(duì)列ID)來(lái)標(biāo)識(shí)。
特點(diǎn)
消息隊(duì)列是面向記錄的,其中的消息具有特定的格式以及特定的優(yōu)先級(jí)。
消息隊(duì)列獨(dú)立于發(fā)送與接收進(jìn)程。進(jìn)程終止時(shí),消息隊(duì)列及其內(nèi)容并不會(huì)被刪除。
消息隊(duì)列可以實(shí)現(xiàn)消息的隨機(jī)查詢,消息不一定要以先進(jìn)先出的次序讀取,也可以按消息的類型讀取。
四、信號(hào)量
信號(hào)量(semaphore)與已經(jīng)介紹過(guò)的 IPC 結(jié)構(gòu)不同,它是一個(gè)計(jì)數(shù)器。信號(hào)量用于實(shí)現(xiàn)進(jìn)程間的互斥與同步,而不是用于存儲(chǔ)進(jìn)程間通信數(shù)據(jù)。
特點(diǎn)
信號(hào)量用于進(jìn)程間同步,若要在進(jìn)程間傳遞數(shù)據(jù)需要結(jié)合共享內(nèi)存。
信號(hào)量基于操作系統(tǒng)的 PV 操作,程序?qū)π盘?hào)量的操作都是原子操作。
每次對(duì)信號(hào)量的 PV 操作不僅限于對(duì)信號(hào)量值加 1 或減 1,而且可以加減任意正整數(shù)。
支持信號(hào)量組。
五、共享內(nèi)存
共享內(nèi)存(Shared Memory),指兩個(gè)或多個(gè)進(jìn)程共享一個(gè)給定的存儲(chǔ)區(qū)。
特點(diǎn)
共享內(nèi)存是最快的一種 IPC,因?yàn)檫M(jìn)程是直接對(duì)內(nèi)存進(jìn)行存取。
因?yàn)槎鄠€(gè)進(jìn)程可以同時(shí)操作,所以需要進(jìn)行同步。
信號(hào)量+共享內(nèi)存通常結(jié)合在一起使用,信號(hào)量用來(lái)同步對(duì)共享內(nèi)存的訪問(wèn)。
以上是“如何實(shí)現(xiàn)進(jìn)程間通信”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!