扩展内容(进程的通信方式)
管道
1) 管道是半雙工的,數據只能向一個方向流動;需要雙方通信時,需要建立起兩個管道;
2) 匿名管道只能用于具有親緣關系的進程,有名管道則沒有限制。
3) 單獨構成一種獨立的文件系統:管道對于管道兩端的進程而言,就是一個文件,但它不是普通的文件,而是單獨構成一種文件系統,只存在與內存中。
管道的實質是一個內核緩沖區,進程以先進先出的方式從緩沖區存取數據:管道一端的進程順序地將進程數據寫入緩沖區,另一端的進程則順序地讀取數據,該緩沖區可以看做一個循環隊列,讀和寫的位置都是自動增加的。
消息隊列
消息隊列,就是一個消息的鏈表,是一系列保存在內核中消息的列表。用戶進程可以向消息隊列添加消息,也可以向消息隊列讀取消息。
消息隊列與管道通信相比,其優勢是對每個消息指定特定的消息類型,接收的時候不需要按照隊列次序,而是可以根據自定義條件接收特定類型的消息。
共享內存
共享內存允許兩個或多個進程共享一個給定的存儲區,通過對一個共享的內存讀取讀出,實現了進程間的通信。
優點是效率高,因為進程可以直接讀寫內存,而不需要任何數據的拷貝,對于像管道和消息隊里等通信方式,則需要再內核和用戶空間進行四次的數據拷貝,而共享內存則只拷貝兩次:一次從輸入文件到共享內存區,另一次從共享內存到輸出文件。
信號量
信號量是一個計數器,可以用來控制多個進程對共享資源的訪問。它可以看作一種鎖機制,作為進程間以及同一進程內不同線程之間的同步手段。
Socket
前面說到的進程間的通信,所通信的進程都是在同一臺計算機上的,而使用socket進行通信的進程可以是同一臺計算機的進程,也是可以是通過網絡連接起來的不同計算機上的進程。
總結
以上是生活随笔為你收集整理的扩展内容(进程的通信方式)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 扩展内容(线程的同步方法)
- 下一篇: 操作系统之存储管理