一般我们写的程序都是以单个进程的方式来运行的,比较少涉及到多进程。特别是在windows下,因为Windows是按照线程来分配CPU时间片的,线程是最小的调度单位,所以在Windows下更多的用到多线程,在同一个进程里创建多个线程来执行不同的任务,达到充分利用CPU的目的。线程之间可以共享进程的资源,比如内存、变量,但是多线程有一个不好的地方,由于这些线程是在同一个进程空间里执行,所以只要一个线程崩溃,整个进程也就崩溃了,程序就退出了。多进程由于是在不同的进程空间里,一个进程崩溃,不会影响到其它的进程,但是进程之间要交换信息的话,就比较麻烦了,不像多线程可以简单的通过一个全局变量来通讯。为了解决进程间交换信息的问题,所以操作系统提供了进程间通讯(IPC)的技术。
现在将Linux和Windows的进程间通信方式好好总结一下:
Windows的进程间的通信方式有:
1. 文件映射
2. 共享内存(是文件映射的一种特殊情况)
3. 邮槽(mailslot)(消息队列MessageQueue)
4. 匿名管道
5. 命名管道
6. 剪贴板
7. 动态数据交换
8. 对象链接与嵌入
9. 远程过程调用(RPC)-Thrift
10. 动态链接库
11. 套接字(socket)
12. WM_COPYDATA
Linux进程间通信的方式有:
1. 管道
2. 信号
3. 共享内存
4. 消息队列(
MessageQueue
)5. 套接字(socket)
6. 信号
Windows和Linux共有的进程间通信方式:
1. 消息(linux中叫做信号)
2. 共享内存
3. 邮槽 (消息队列MessageQueue)
4. 管道
5. 套接字(socket)