共享內(nèi)存
是被多個(gè)進(jìn)程共享的一部分物理內(nèi)存。共享內(nèi)存是進(jìn)程間共享數(shù)據(jù)的一種最快的方法,一個(gè)進(jìn)程向共享內(nèi)存區(qū)域?qū)懭肓藬?shù)據(jù),共享這個(gè)內(nèi)存區(qū)域的所有進(jìn)程就可以立刻看到其中的內(nèi)容
共享內(nèi)存實(shí)現(xiàn)分為兩個(gè)步驟:
一、創(chuàng)建共享內(nèi)存,使用shmget函數(shù)
二、映射共享內(nèi)存,將這段創(chuàng)建的共享內(nèi)存映射到具體的進(jìn)程空間去,使用shmat函數(shù)
當(dāng)一個(gè)進(jìn)程不再需要共享內(nèi)存時(shí),需要把它從進(jìn)程地址空間中脫離。
int shmdt ( char *shmaddr )
消息隊(duì)列
unix早期通信機(jī)制之一的信號(hào)能夠傳送的信息量有限,管道則只能傳送無(wú)格式的字節(jié)流,這無(wú)疑會(huì)給應(yīng)用程序開發(fā)帶來(lái)不便。消息隊(duì)列(也叫做報(bào)文隊(duì)列)則克服了這些缺點(diǎn)。
發(fā)展
消息隊(duì)列就是一個(gè)消息的鏈表??梢园严⒖醋饕粋€(gè)記錄,具有特定的格式。進(jìn)程可以向中按照一定的規(guī)則添加新消息;另一些進(jìn)程則可以從消息隊(duì)列中讀走消息
目前主要有兩種類型的消息隊(duì)列:
POSIX消息隊(duì)列以及系統(tǒng)V消息隊(duì)列,系統(tǒng)V消息隊(duì)列目前被大量使用
系統(tǒng)V消息隊(duì)列是隨內(nèi)核持續(xù)的,只有在內(nèi)核重起或者人工刪除時(shí),該消息隊(duì)列才會(huì)被刪除
鍵值
消息隊(duì)列的內(nèi)核持續(xù)性要求每個(gè)消息隊(duì)列都在系統(tǒng)范圍內(nèi)對(duì)應(yīng)唯一的鍵值,所以,要獲得一個(gè)消息隊(duì)列的描述字,必須提供該消息隊(duì)列的鍵值
在以下兩種情況下,將創(chuàng)建一個(gè)新的消息隊(duì)列:
1、如果沒有與健值key相對(duì)應(yīng)的消息隊(duì)列,并且 msgflg中包含了IPC_CREAT標(biāo)志位。
2、key參數(shù)為IPC_PRIVATE
發(fā)送消息
include #include #include int msgsnd(int msqid,struct msgbuf*msgp,int msgsz,int msgflg
功能:向消息隊(duì)列中發(fā)送一條消息
Msqid: 已打開的消息隊(duì)列id
Msgp: 存放消息的結(jié)構(gòu)
Msgsz: 消息數(shù)據(jù)長(zhǎng)度
Msgflg:
發(fā)送標(biāo)志,有意義的msgflg標(biāo)志為IPC_NOWAIT,指明在消息隊(duì)列沒有足夠空間容納要發(fā)送的消息時(shí),msgsnd是否等待
消息格式
struct msgbuf { long mtype;/*消息類型*/ char mtext[1]; /*消息數(shù)據(jù)的首地址*/ } *接收消息* #include #include #include int msgrcv(int msqid, struct msgbuf *msgp, int msgsz, long msgtyp, int msgflg)
功能:
從msqid代表的消息隊(duì)列中讀取一個(gè)msgtyp類型的消息,并把消息存儲(chǔ)在msgp指向的msgbuf結(jié)構(gòu)中。在成功地讀取了一條消息以后,隊(duì)列中的這條消息將被刪除
信號(hào)量
信號(hào)量(又名:信號(hào)燈)與其他進(jìn)程間通信方式不大相同,主要用途是保護(hù)臨界資源。
進(jìn)程可以根據(jù)它判定是否能夠訪問某些共享資源。除了用于訪問控制外,還可用于進(jìn)程同步
分類
二值信號(hào)燈:信號(hào)燈的值只能取0或1,類似于互斥鎖。 但兩者有不同:
信號(hào)燈強(qiáng)調(diào)共享資源,只要共享資源可用,其他進(jìn)程同樣可以修改信號(hào)燈的值;
互斥鎖更強(qiáng)調(diào)進(jìn)程,占用資源的進(jìn)程使用完資源后,必須由進(jìn)程本身來(lái)解鎖。
計(jì)數(shù)信號(hào)燈:信號(hào)燈的值可以取任意非負(fù)值