类别 | 说明 |
无名管道pipe | 仅能用于亲缘关系进程间通信,pipe函数可以创建读写管道,当父子进程可以相互收发消息时,注意自己发的消息不要被自己接收到了 |
有名管道fifo | 以fifo文件作为通信媒介,与普通文件最大的不同在于fifo文件中的内容被读取后就没了,且只能以只读或者只写方式打开。 |
信号 | 可以通过signal函数改变信号的处理方式,如用函数处理信号signal(SIGINT, fun),Ctrl+C会直接调用fun函数,恢复信号默认处理方式signal(SIGINT, SIG_DFL) |
消息队列 | 独立于进程而存在,可以根据消息类型有选择接受消息,缺点是消息大小有上限。 |
共享内存 | 创建共享内存,挂接到进程,并将其转为自定义结构体变量,访问速度快,不具备同步机制,消息大小有上限 |
信号量 | 通过PV操作的控制信号的获取和释放,以此解决资源访问竞争问题。 |
套接字 | 利用网络编程来通信,容易扩展到多台机器 |
eventfd | 用eventfd函数创建一个事件描述符,可以通过内核唤醒用户态事件,通过read\write来通信。 |
总结下进程间通信的方式
最新推荐文章于 2023-12-29 14:36:02 发布