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