今天从进程间通信看起:
1、pipe():
pipe()->sys_pipe()->do_pipe(fd) 这里fd是一个数组fd[2]代表管道打开的两个文件。->get_pipe_innode() 在这个函数里定义了一个inode结构只有在其i_pipe是非空时有效,i_Pipe指向inode文件结构(管道)。在管道里使用两个指针指向两个文件,一个文件只读,一个文件只写,而这两个文件又指向同一个Inode。
但是我们从刚才的叙述可以知道这样的话仅限于在同一个同一个进程里面的两个打开的文件,那么进程间是怎么通信的呢?其过程如下:
process A创建了一个process B,这样两个proecss共享了所有文件,而A关闭读端,B关闭写段这个样AB之间就可以通信了。A fork 一个C,A关闭写端,这样AC就没有关系了,但是写端在B里面还存在的,这样BC之间就可通信了。
这就是为什么管道命令一个进程的输出是另一个的输入了。