pipe是Linux系統中的管道,管道機制的主體是pipe函數的調用,那麼Linux系統要如何建立pipe函數呢?下面小編就給大家介紹下Linux建立pipe函數的方法,一起來了解下吧。
● 無名管道
主要用於父進程與子進程之間,或者兩個兄弟進程之間。在linux系統中可以通過系統調用建立起一個單向的通信管道,且這種關系只能由父進程來建立。因此,每個管道都是單向的,當需要雙向通信時就需要建立起兩個管道。管道兩端的進程均將該管道看做一個文件,一個進程負責往管道中寫內容,而另一個從管道中讀取。這種傳輸遵循“先入先出”(FIFO)的規則。
● 命名管道
命名管道是為了解決無名管道只能用於近親進程之間通信的缺陷而設計的。命名管道是建立在實際的磁盤介質或文件系統(而不是只存在於內存中)上有自己名字的文件,任何進程可以在任何時間通過文件名或路徑名與該文件建立聯系。為了實現命名管道,引入了一種新的文件類型——FIFO文件(遵循先進先出的原則)。實現一個命名管道實際上就是實現一個FIFO文件。命名管道一旦建立,之後它的讀、寫以及關閉操作都與普通管道完全相同。雖然FIFO文件的inode節點在磁盤上,但是僅是一個節點而已,文件的數據還是存在於內存緩沖頁面中,和普通管道相同。
1. 函數說明
pipe(建立管道):
1) 頭文件 #include《unistd.h》
2) 定義函數: int pipe(int filedes[2]);
3) 函數說明: pipe()會建立管道,並將文件描述詞由參數filedes數組返回。
filedes[0]為管道裡的讀取端
filedes[1]則為管道的寫入端。
4) 返回值: 若成功則返回零,否則返回-1,錯誤原因存於errno中。
錯誤代碼:
EMFILE 進程已用完文件描述詞最大量
ENFILE 系統已無文件描述詞可用。
EFAULT 參數 filedes 數組地址不合法。
2. 舉例
[cpp] view plaincopy
#include 《unistd.h》
#include 《stdio.h》
int main( void )
{
int filedes[2];
char buf[80];
pid_t pid;
pipe( filedes );
pid=fork();
if (pid 》 0)
{
printf( “This is in the father process,here write a string to the pipe./n” );
char s[] = “Hello world , this is write by pipe./n”;
write( filedes[1], s, sizeof(s) );
close( filedes[0] );
close( filedes[1] );
}
else if(pid == 0)
{
printf( “This is in the child process,here read a string from the pipe./n” );
read( filedes[0], buf, sizeof(buf) );
printf( “%s/n”, buf );
close( filedes[0] );
close( filedes[1] );
}
waitpid( pid, NULL, 0 );
return 0;
}
運行結果:
[root@localhost src]# gcc pipe.c
[root@localhost src]# 。/a.out
This is in the child process,here read a string from the pipe.
This is in the father process,here write a string to the pipe.
Hello world , this is write by pipe.
當管道中的數據被讀取後,管道為空。一個隨後的read()調用將默認的被阻塞,等待某些數據寫入。
若需要設置為非阻塞,則可做如下設置:
fcntl(filedes[0], F_SETFL, O_NONBLOCK);
fcntl(filedes[1], F_SETFL, O_NONBLOCK);
上面就是Linux建立pipe管道函數的方法介紹了,需要注意的是,pipe函數需要和fork()配合使用,否則起不到進程間通信的作用。