關於Linux系統下IPC筆記

linux下進程間通信的幾種主要手段簡介:
   1. 管道(Pipe)及有名管道(named pipe):管道可用於具有親緣關係進程間的通信,有名管道克服了管道沒有名字的限制,因此,除具有管道所具有的功能外,它還允許無親緣關係進程間的通信;
   2. 信號(Signal):信號是比較複雜的通信方式,用於通知接受進程有某種事件發生,除了用於進程間通信外,進程還可以發送信號給進程本身;linux除了支持Unix早期信號語義函數sigal外,還支持語義符合Posix.1標準的信號函數sigaction(實際上,該函數是基於BSD的,BSD爲了實現可靠信號機制,又能夠統一對外接口,用sigaction函數重新實現了signal函數);
   3. 報文(Message)隊列(消息隊列):消息隊列是消息的鏈接表,包括Posix消息隊列system V消息隊列。有足夠權限的進程可以向隊列中添加消息,被賦予讀權限的進程則可以讀走隊列中的消息。消息隊列克服了信號承載信息量少,管道只能承載無格式字節流以及緩衝區大小受限等缺點。
   4. 共享內存:使得多個進程可以訪問同一塊內存空間,是最快的可用IPC形式。是針對其他通信機制運行效率較低而設計的。往往與其它通信機制,如信號量結合使用,來達到進程間的同步及互斥。
   5. 信號量(semaphore):主要作爲進程間以及同一進程不同線程之間的同步手段。
   6. 套接口(Socket):更爲一般的進程間通信機制,可用於不同機器之間的進程間通信。起初是由Unix系統的BSD分支開發出來的,但現在一般可以移植到其它類Unix系統上:Linux和System V的變種都支持套接字。

Linux環境進程間通信(一)之管道(pipe &FIFO)
Linux環境進程間通信(二): 信號(上)
Linux環境進程間通信(二): 信號(下)
Linux環境進程間通信(三)之消息隊列(msg)
Linux環境進程間通信(四)之信號量
Linux環境進程間通信(五): 共享內存(上)之映射普通文件
Linux環境進程間通信(五): 共享內存(下)之映射內存
Linux環境進程間通信(六):之套接字

 

 

另外關於共享內存應用中的問題及解決方法可以參考:
    http://www.ibm.com/developerworks/cn/aix/library/au-cn-sharemem/index.html#N1008B

發佈了26 篇原創文章 · 獲贊 3 · 訪問量 9萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章