每个进程中的数据在另一个进程中都是看不到的,如果要进行数据交换,就需要进行进程间的通信,就需要内核的参与,在内核中开辟一块缓冲区,进程1将数据拷贝到缓冲区,进程二再从缓冲区将数据拿走,内核提供的这种机制叫做进程间的通信。
1. 管道/匿名管道:用于具有亲缘关系的父子进程或者兄弟进程之间的通信。
2. 有名管道:因为匿名管道没有名字,只能用于亲缘关系之间的进程通信,所以为了克服这个缺点,使用有名管道,有名管道严格遵循先进先出,有名管道以文件形式存在于系统之中,这样只要访问文件路径就可以,就可以通过管道实现进程通信。
3. 信号(signal):比较复杂的一种通信方式,用于通知接收进程某个事件已经发生。
4. 消息队列(Message):消息队列是消息的链表,具有特定的格式,存放在内存中,并由消息队列标识符标识,管道和消息队列都遵循先进先出的原则。与管道不同的是消息队列存放着内核中,只有内核重启或者删除一个消息队列,该消息队列才会被删除。消息队列可以实现消息的随机查询。消息不一定以先进先出的顺序读取,也可以按照消息类型读取。消息队列克服了信号承载信息量少,管道只能承载无格式字节流以及缓冲区大小受限等缺。
5. 信号量:信号量是一个计数器,用于多线程对共享数据的同步。
6. 共享内存:使得多个线程可以访问同一块内存空间,在内核中专门留出来一块内存区域,使得进程可以直接读取,不需要进行数据的拷贝。
7. 套接字(Sockets):用于客户端/服务器之间的网络通信。