Linux進程爲什麼通信和主要通信手段

爲什麼要進程需要通信?

1、數據共享:一個進程需要將它的數據發給另一個進程。

2、資源共享:多個進程之間共享同樣的資源。

3、通知事件:一個進程需要向另一個或一組進程發送消息,通知它們發生了某種事件。

4、進程控制:有些進程希望完全控制另一個進程的執行,此時控制進程希望能夠攔截另一個進程的所有操作、並能夠及時知道它的狀態改變。

Linux進程通信(IPC)由以下幾部分發展而來:

1、UNIX進程間通信

2、基於SystemV進程間通信

3、POSIX進程間通信

Linux下進程間通信的幾種主要手段:

1、管道及命名管道:管道可用於具有親緣關係進程間的通信,命名管道克服管道沒有名字的限制,因此,除具有管道所具有的功能外,它還允許無親緣進程間的通信。

2、信號:信號是比較複雜的通信方式,用於通知接受進程有某種事件發生除了用於進程通信外,進程還可以發送信號給進程本身;Linux除了支持Unix早期信號語義函數signal外,還支持語義符合Posix.1標準的信號函數sigaction。

3、報文隊列:消息隊列是消息的連接表,包括Posix消息隊列systemV消息隊列。有足夠權限的進程可以向隊列中添加消息,被賦予讀權限的進程可以讀走隊列中的消息。消息隊列克服了信號承載信息量少,管道只能承載無格式字節流以及緩衝區大小受限等缺點。

4、共享內存:使得多個進程可以訪問同一塊內存空間,是最快的可用IPC形式。針對其他通信機制運行效率較低而設計的。往往與其他通信機制,如信號量結合使用,來達到進程間的同步及互斥。

5、信號量:主要作爲進程間以及同一進程不同線程之間的同步手段。

6、套接口:更爲一般的進程間通信機制,可用於不同機器之間的進程間通信。起初是由Unix系統的BSD分支開發出來的,但現在一般可以移植到其他類Unix系統上:Linux和System V的變種都支持套接字。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章