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