1. 什么是进程间通信
每个进程的用户地址空间都是独立的,一般而言不能互相访问,但内核空间是每个进程都共享的,所以进程之间要通信必须通过内核。
在32位Linux系统下,进程的虚拟地址空间大小为 4G,其中高地址的 1G是内核地址空间,其余 3G是用户空地址空间。用户地址空间对于每个进程来说是独立的,但每个进程的内核地址空间关联的都是相同的物理内存。
进程在用户态时,只能访问用户地址空间的内存;只有切换到内核态后,才可以访问内核空间的内存。
2. 进程间通信的六种方式:
1.管道(pipe)及有名管道(named pipe):
管道可用于具有亲缘关系进程间的通信,有名管道除了具有管道所具有的功能外,它还允许无亲缘关系进程间的通信。
优缺点:大小空间有限,不适合大量的数据传送
2.信号(signal):
信号是在软件层次上对中断机制的一种模拟,它是比较复杂的通信方式,用于通知进程有某事件发生,一个进程收到一个信号与处理器收到一个中断请求效果上可以说是一致得。
3.消息队列(message queue):
消息队列是消息的链接表,它克服了上两种通信方式中信号量有限的缺点,具有写权限得进程可以按照一定得规则向消息队列中添加新信息;对消息队列有读权限得进程则可以从消息队列中读取信息。
优缺点:存在两次数据copy,核外的cpu消耗,不适合频繁和数据量大的数据
4.共享内存(shared memory):
可以说这是最有用的进程间通信方式。它使得多个进程可以访问同一块内存空间,不同进程可以及时看到对方进程中对共享内存中数据得更新。这种方式需要依靠某种同步操作,如互斥锁和信号量等。
优缺点:没有同步机制
5.信号量(semaphore):
主要作为进程之间及同一种进程的不同线程之间得同步和互斥手段。
优缺点:同步的手段,不适合数据传输
6.套接字(socket);
这是一种更为一般得进程间通信机制,它可用于网络中不同机器之间的进程间通信,应用非常广泛。
优缺点:网络传输效率低