进程间通讯--管道
管道:把一個進程連接到另一個進程的一個數據流稱為一個“管道”,通常是用作把一個進程的輸出通過管道連接到另一個進程的輸入。管道本質上是內核的一塊緩存
?
匿名管道是基于文件描述符的通信方式。實現兩個進程間的通信時必須通過fork創建子進程,實現父子進程之間的通信
?
讀寫規則
管道內沒有數據時,讀端(read)發生阻塞,等待有效數據進行讀取
管道容量被數據填滿時,寫端(write)發生阻塞,等待進程將數據讀走再進行寫入
如果所有管道寫端對應的文件描述符被關閉,read返回0,但會將之前管道里的數據讀完
如果所有管道的讀端對應的文件描述符被關閉,write操作會產生信號,SIGPIPE,進而導致write進程退出
當要寫入的數據量不大于管道的容量(PIPE_BUF)時,linux將保證寫入的原子性
當要寫入的數據量大于管道容量(PIPE_BUF)時,linux將不再保證寫入的原子性
?
特點
只能夠進行單向通信
只能夠用于有血緣關系(父子,兄弟,爺孫)的進程之間,多常用于父子之間
管道內部自帶同步機制:子進程寫一條,父進程讀一條
管道在進行通信的時候,對外層提供的服務叫做面向字節流的服務
當進程退出之時,管道也隨之釋放,與文件保持一致
管道的生命周期為隨進程,進程結束管道就沒了
字節流:以字節來讀取和寫入,字節數的大小完全取決于自己
?
命名管道本質上是一個管道文件,可以通過命令創建也可以通過函數創建,用戶可以看到
特點
??1. 可以進行不相干進程間的通信
??2. 命名管道是一個文件,對于文件的相關操作對其同樣適用讀寫規則
??1. 對于管道文件,當前進程操作為只讀時,則進行阻塞,直至有進程對其寫入數據
??2. 對于管道文件,當前進程操作為只寫時,則進行阻塞,直至有進程從管道中讀取數據
總結
- 上一篇: send/recv阻塞和非租塞不同
- 下一篇: 同步通信和异步通信区别