由于各个进程之间独享一块用户地址空间,一般而言这块独立的用户地址空间不能互相访问,所以进程之间想要通信必须通过内核空间(每个进程共享)。
进程间的通信方式主要有以下几种:
信号
Linux操作系统中,为了响应各种各样的事件,提供了很多信号,可以通过kill -l命令来查看所有的信号。
Socket
前面的进程间通信都仅限于同一台主机,如果需要跨网络上的不同主机上的进程之间进行通信,就需要通过Socket(Socket也可以在同一台主机上通信)。
int socket(int domain, int type, int protocal)
基于TCP的Socket通信
监听和传输数据的SOCKET是两个SOCKET,连接成功建立以后,双方通过read和write来读写进程。
基于UDP的Socket通信
UDP是无连接的,因此不需要三次握手,不需要调用listen和connect,但是UDP的交互仍然需要bind IP地址和端口。
每次通信调用sendto和recvfrom时都需要传入目标主机的IP地址和端口。
本地Socket通信
本地Socket支持字节流和数据报两种格式:
本地socket不像跨网络主机通信需要绑定IP和端口,而是绑定本地一个文件