总结下进程间通信的方式

类别

说明

无名管道pipe

仅能用于亲缘关系进程间通信,pipe函数可以创建读写管道,当父子进程可以相互收发消息时,注意自己发的消息不要被自己接收到了

有名管道fifo

fifo文件作为通信媒介,与普通文件最大的不同在于fifo文件中的内容被读取后就没了,且只能以只读或者只写方式打开。

信号

可以通过signal函数改变信号的处理方式,如用函数处理信号signal(SIGINT, fun)Ctrl+C会直接调用fun函数,恢复信号默认处理方式signal(SIGINT, SIG_DFL)

消息队列

独立于进程而存在,可以根据消息类型有选择接受消息,缺点是消息大小有上限。

共享内存

创建共享内存,挂接到进程,并将其转为自定义结构体变量,访问速度快,不具备同步机制,消息大小有上限

信号量

通过PV操作的控制信号的获取和释放,以此解决资源访问竞争问题。

套接字

利用网络编程来通信,容易扩展到多台机器

eventfd

eventfd函数创建一个事件描述符,可以通过内核唤醒用户态事件,通过read\write来通信。


你可能感兴趣的:(总结下进程间通信的方式)