进程间通信就是在不同进程之间传播或交换信息,进程的用户空间是相互独立的,一般而言是不可以互相访问(除共享内存区外),系统空间却是“公众场所”,通过通信方法:管道(pipe)(有名管道FIFO)、消息队列、信号量(semaphore)、共享内存(shared memory)、套接字(socket)等实现功能。
进程间通信的主要目的在于:数据传输(管道pipe),共享数据,通知事件,资源共享,进程控制
管道通信:管道是单向的,先进先出,尾部写入数据,头部读出数据
无名管道用于父子进程间的通信,有名管道用于同一系统下的兄弟进程间的通信。
无名管道创建API:int pipe(int filedis[2])(当一个管道建立,会产生两个文件描述符,filedis[0]读管道,filedis[1]写管道)
有名管道创建API:int mkfifo(const char *pathname,mode_t mode)(pathname:FIFO文件名 mode:属性)
信号通信:最为古老的进程间通信机制
常见信号:SIGHUP(来自终端的结束信号) 、SIGINT(来自键盘的中断信号) 、SIGKI