linux 进程间通信——管道

基本应用

  1. 无名管道(pipe)
//1. 创建一个有两个元素的一维数组 	
int pipe[2];
//2. 使用pipe或pipe2函数将数组变为无名管道 
if(0 == pipe(pipe)) //(pipe[0]--读,pipe[1]--写)
//3. 创建一个子进程 
pid_t pid = fork();
//4. 子进程和父进程按需要关闭其中一端
if(pid == 0) //子进程
{
	if(child write to parent)
		close(pipe[0]);
	else
		close(pipe[1]);
}
else if(pid > 0) //父进程
{
	if(child write to parent)
  		close(pipe[1]);
 	else
  		close(pipe[0]);
}

}
else 
	//fork出错
  1. 有名管道(fifo)
//1. 定义一个有效文件路径
char *path = ".";	//当前目录路径
//2. 创建有名管道fifo
mkfifo(path, 0644);
//3. 打开有名管道
int fd = open(path, flag);

无名管道双向通信的可行性

  1. 上面无名管道的基本应用中会关闭一端,这样是为什么?
    是无名管道不能双向通信吗? 可以!子进程和父进程既可以通过一个无名管道读也可以写。
  2. 那为什么用关闭一端呢?
    a. 因为无名管道的读端和写端用的是一块内存;
    b. 子进程写进去的内容也可能被子进程读出来;
    c. 如果子进程和父进程同时读,这可能会同时阻塞在读上,从而造成死锁。

你可能感兴趣的:(linux,进程)