fork() 函式:
返回0時是子程序,否則,是父程序。
pipe函式
int pipe(int filedes[2]);
返回值:成功,返回0,否則返回-1。引數陣列包含pipe使用的兩個檔案的描述符。fd[0]:讀管道,fd[1]:寫管道。
必須在fork()中呼叫pipe(),否則子程序不會繼承檔案描述符。兩個程序不共享祖先程序,就不能使用pipe。但是可以使用命名管道。
當管道進行寫入操作的時候,如果寫入的資料小於128k則是非原子的,如果大於128k位元組,緩衝區的資料將被連續地寫入
管道,直到全部資料寫完為止,如果沒有程序讀取資料,則將一直阻塞
命名管道fifo
管道最大的劣勢就是沒有名字,只能用於有乙個共同祖先程序的各個程序之間。fifo代表先進先出,單它是乙個單向資料流,也就是半雙工,和
管道不同的是:每個fifo都有乙個路徑與之關聯,從而允許無親緣關係的程序訪問。
#include
#include
int mkfifo(const char *pathname, mode_t mode);
這裡pathname是路徑名,mode是sys/stat.h裡面定義的建立檔案的許可權.
以下示例程式來自:
從例子上可以看出使用fifo時需要注意:
*fifo管道是先呼叫mkfifo建立,然後再用open開啟得到fd來使用.
*在開啟fifo時要注意,它是半雙工的的,一般不能使用o_rdwr開啟,而只能用唯讀或只寫開啟.
fifo可以用在非親緣關係的程序間,而它的真正用途是在伺服器和客戶端之間. 由於它是半雙工的所以,如果要進行客戶端和伺服器雙方的通訊的話,
每個方向都必須建立兩個管道,乙個用於讀,乙個用於寫.
用於檔案描述符對應的檔案中讀取資料,原型:
ssize_t read(int fd,void*buf,size_t count)返回值:引數說明:
fd: 是檔案描述符, 從command line獲取資料時,為0
buf: 為讀出資料的緩衝區;
count: 為每次讀取的位元組數(是請求讀取的位元組數,讀上來的資料保
存在緩衝區buf中,同時檔案的當前讀寫位置向後移)
成功:返回讀出的位元組數用於將資料寫入到檔案描述符對應的檔案,原型:失敗:返回-1,並設定errno,如果在呼叫read
之前到達檔案末尾,則這次read返回0
ssize_t write(int fd,const void*buf,size_t count);返回值:引數說明:
fd:是檔案描述符(輸出到command line,就是1)
buf:通常是乙個字串,需要寫入的字串
count:是每次寫入的位元組數
成功:返回寫入的位元組數例項:以下程式再提供全雙工管道的系統下,能夠看到失敗:返回-1並設定errno
ps: 寫常規檔案時,write的返回值通常等於請求寫的位元組
數count, 而向終端裝置或者網路寫時則不一定
child read p
parent read c
再預設提供半雙工管道的系統下,則會出錯。
}參考:
全雙工半雙工
單工 單工就是指a只能發訊號,而b只能接收訊號,通訊是單向的,就象燈塔之於航船 燈塔發出光訊號而航船只能接收訊號以確保自己行駛在正確的航線上。半雙工 指乙個時間段內只有乙個動作發生,舉個簡單例子,一天窄窄的馬路,同時只能有一輛車通過,當目前有兩量車對開,這種情況下就只能一輛先過,等到頭兒後另一輛再開...
單工,半雙工,全雙工
1 單工 單工就是指a只能發訊號,而b只能接收訊號,通訊是單向的,就象燈塔之於航船 燈塔發出光訊號而航船只能接收訊號以確保自己行駛在正確的航線上。2 半雙工 half duplex 半雙工就是指a能發訊號給b,b也能發訊號給a,但這兩個過程不能同時進行。最典型的例子就象我們在影視作品中看到的對講機一...
Notes 全雙工和半雙工
在通訊中,資料通常是在兩個終端 如電腦和外設 之間進行傳送,根據資料流的傳輸方向可分為3種基本傳送方式 單工 半雙工和全雙工。1 單工通訊 單工通訊只有乙個資料通路,資訊只能在這個通路上往乙個固定的方向 無法變換方向 傳輸,比如電視機就是這種通訊方式。2 半雙工通訊 半雙工通訊也只有乙個資料通路,但...