总结下进程间通信的方式

类别

说明

无名管道pipe

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

有名管道fifo

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

信号

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

消息队列

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

共享内存

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

信号量

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

套接字

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

eventfd

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


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值