进程间通讯:
A 进程将“hello world”传递给 B 进程。
1.1 管道实现原理
![这里写图片描述](https://img-blog.csdn.net/20170930163226509?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvU2FrdXJhX2NoZXJyeQ==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
通过在内存上开辟一块全新的空间,A,B 进程都通过文件描述符操作这块空间。以完成数据交互的功能。
1.2. 创建管道文件命令:
mkfifo 命令 mkfifo();函数
1.3 使用管道文件传递信息:
打开: open
读取数据:read
写数据: write
关闭: close
1.4 管道文件操作特点:
如果一个进程以只写打开管道,但是没有以只读或读写打开这个管道的进程,则打开操作会阻塞, 直到有进程以读或读写打开,open 才会返回。
如果一个进程以只读打开管道,但是没有以只写或读写打开这个管道的进程,则打开操作会阻塞, 直到有进程以写或读写打开,open 才会返回。
当写端没有写入数据时,读端会阻塞到 read 调用,直到写端写入数据或者写端关闭。
当管道没有空间时,再写入数据就会被阻塞。直到有进程读取数据,或者所有的读端关闭。
<