IPC 进程间通信
2024-09-28 18:07:58
linux下进程间通信的几种主要手段简介:
- 管道(Pipe)及有名管道(named pipe):管道可用于具有亲缘关系进程间的通信,有名管道克服了管道没有名字的限制,因此,除具有管道所具有的功能外,它还允许无亲缘关系进程间的通信;
- 信号(Signal):信号是比较复杂的通信方式,用于通知接受进程有某种事件发生,除了用于进程间通信外,进程还可以发送信号给进程本身;linux除了支持Unix早期信号语义函数sigal外,还支持语义符合Posix.1标准的信号函数sigaction(实际上,该函数是基于BSD的,BSD为了实现可靠信号机制,又能够统一对外接口,用sigaction函数重新实现了signal函数);
- 报文(Message)队列(消息队列):消息队列是消息的链接表,包括Posix消息队列system V消息队列。有足够权限的进程可以向队列中添加消息,被赋予读权限的进程则可以读走队列中的消息。消息队列克服了信号承载信息量少,管道只能承载无格式字节流以及缓冲区大小受限等缺点。
- 共享内存:使得多个进程可以访问同一块内存空间,是最快的可用IPC形式。是针对其他通信机制运行效率较低而设计的。往往与其它通信机制,如信号量结合使用,来达到进程间的同步及互斥。
- 信号量(semaphore):主要作为进程间以及同一进程不同线程之间的同步手段。
- 套接口(Socket):更为一般的进程间通信机制,可用于不同机器之间的进程间通信。起初是由Unix系统的BSD分支开发出来的,但现在一般可以移植到其它类Unix系统上:Linux和System V的变种都支持套接字。
最新文章
- Screen Orientation for Windows Phone
- 【LeetCode】#344 Reverse String
- (SenchaTouch+PhoneGap)开发笔记(2)开发环境搭建二
- Linux 随机生成随机数
- ——YC,你学到了吗?——学到了学到了
- ubuntu下minicom和USB转串口(转)
- Edius 安装 looks插件整理
- 调用 GetProcAddress 失败,在 ISAPI 筛选器 ";C:\Windows\Microsoft.NET\Framework\v4.0.30319\aspnet_isapi.dll"; 上
- js 人工获取年月日
- [Android]在Dagger 2中Activities和Subcomponents的多绑定(翻译)
- Linux下glui 的安装,以及错误解决
- 微信小程序之----audio音频播放
- hadoop2的mapreduce操作hbase数据
- 初识Go语言
- Python中文词频统计
- JQuery的Ajax技术
- react学习三
- 矩阵NumPy
- computational biology | Bioinformatician | 开发者指南
- [LeetCode] Climbing Stairs (Sequence DP)
热门文章
- 【转】在服务器上排除问题的头五分钟&;常用命令
- java读取本地文件
- VMware虚拟机安装(二)
- Python3.6全栈开发实例[003]
- 中文Ubuntu里用户目录里的路径改成英文
- MySQL如何优化GROUP BY :松散索引扫描 VS 紧凑索引扫描
- (4.7)怎么捕获和记录SQL Server中发生的死锁?
- 001-web基本程序搭建
- PyNest——part 2: populations of neurons
- iOS Swift 熊猫🐼跑酷 第一个小项目