进程间通信的目的:
1 数据传输:一个进程需要将他的数据发送到另一个进程,发送的数量在一个字节到几兆字节之间。
2 共享数据:多个进程想要操作共享数据,一个进程对共享数据的修改,别的进程应该立刻看到。
3 通知事件: 一个进程向另一个或另一组发送信息,通知它发生了某种事件。
4 资源共享:多个进程之间共享相同的资源,为了实现这一点,需要内核提供锁和同步机制。
5进程控制:有些进程希望完全控制另一个进程的执行,此时控制进程希望能够拦截另一个进程的所有陷入和异常,并能够及时知道他的状态。
进程间通信的主要方式
1 ** 管道(pipe)和有名管道(fifo)
2 信号(signal)
3 **消息队列
4 **共享内存
5 **信号量
6 套接字
**无名管道**
pipe() 建立管道
file[0] 为管道里的读取端 file[1]为管道里的写入端;
通常先建立一个管道,然后用fork函数再创建一个子进程,子进程继承父进程所创建的管道。 注意:系统调用fork函数前必须调用pipe,顺序不能反。 //先创建管道,再创建进程。