文本参考自 https://www.cnblogs.com/zgq0/p/8780893.html
这个也是面试中经常问的,不过说实话java程序员根本就接触不到的,背也是死记硬背,不过最近看redis设计和实现 C语言的程序才会真正的用到进程间通信。
比如进行AOF写的时候,fork一个子进程,子进程完成了之后会通知父进程。父进程再把写AOF文件的中间产生的增量操作,再次追加到AOF文件里。这里提到的子进程通知才是进程间通信。
一、管道
管道,通常指无名管道,是 UNIX 系统IPC最古老的形式。
1、特点:
它是半双工的(即数据只能在一个方向上流动),具有固定的读端和写端。
它只能用于具有亲缘关系的进程之间的通信(也是父子进程或者兄弟进程之间)。
它可以看成是一种特殊的文件,对于它的读写也可以使用普通的read、write 等函数。但是它不是普通的文件,并不属于其他任何文件系统,并且只存在于内存中。
2、原型:
1 #include
2 int pipe(int fd[2]); // 返回值:若成功返回0,失败返回-1
当一个管道建立时,它会创建两个文件描述符:fd[0]为读而打开,fd[1]为写而打开。如下图:
要关闭管道只需将这两个文件描述符关闭即可。
3