进程同步和进程通信总结
来源:互联网 发布:佛经app软件 编辑:程序博客网 时间:2024/06/09 15:23
在Linux下:
进程同步的意思是说,让不同进程能够在同时到达一个已知的特定状态之前等待另一方的执行。Linux 下常见的同步方法有SysVIPC 的 sem(信号量)、file locking / record locking(通过 fcntl 设定的文件锁、记录锁)、futex(基于共享内存的快速用户态互斥锁)。针对线程(pthread)的还有 pthread_mutex 和 pthread_cond(条件变量)。
进程间通信的方法:
1. 管道(Pipe)及有名管道(named pipe):管道可用于具有亲缘关系进程间的通信,有名管道克服了管道没有名字的限制,因此,除具有管道所具有的功能外,它还允许无亲缘关系进程间的通信;
2. 信号(Signal):信号是比较复杂的通信方式,用于通知接受进程有某种事件发生,除了用于进程间通信外,进程还可以发送信号给进程本身;linux除了支持Unix早期信号语义函数sigal外,还支持语义符合Posix.1标准的信号函数 sigaction(实际上,该函数是基于BSD的,BSD为了实现可靠信号机制,又能够统一对外接口,用sigaction函数重新实现了signal 函数);
3. 报文(Message)队列(消息队列):消息队列是消息的链接表,包括Posix消息队列system V消息队列。有足够权限的进程可以向队列中添加消息,被赋予读权限的进程则可以读走队列中的消息。消息队列克服了信号承载信息量少,管道只能承载无格式字节流以及缓冲区大小受限等缺点。
4. 共享内存:使得多个进程可以访问同一块内存空间,是最快的可用IPC形式。是针对其他通信机制运行效率较低而设计的。往往与其它通信机制,如信号量结合使用,来达到进程间的同步及互斥。
5. 信号量(semaphore):主要作为进程间以及同一进程不同线程之间的同步手段。
6. 套接口(Socket):更为一般的进程间通信机制,可用于不同机器之间的进程间通信。起初是由Unix系统的BSD分支开发出来的,但现在一般可以移植到其它类Unix系统上:Linux和System V的变种都支持套接字
- 进程同步和进程通信总结
- 进程间通信和同步
- linux 进程通信和同步
- 多进程间通信方式和多线程同步机制总结
- 多进程间通信方式和多线程同步机制总结
- 多进程间通信方式和多线程同步机制总结
- 多进程间通信方式和多线程同步机制总结
- 多进程间通信方式和多线程同步机制总结
- 进程通信/线程同步方式总结
- 进程线程同步 进程通信
- 线程间同步和进程间通信
- 线程进程通信和同步方式
- 进程间通信 和 线程间同步
- 进程间通信和线程同步结构图
- 进程同步与通信
- 线程 进程 同步 通信
- 进程通信&线程同步
- 进程间通信,同步
- 一个小项目构思 - 曲谱平台
- IFRAME的一些知识点
- Android 中的拿来主义(编译,反编译,AXMLPrinter2,smali,baksmali)!
- thinkpad T61使用中突然关机,按主机电源后无法开机
- Linux动态库(一)之同名符号
- 进程同步和进程通信总结
- 硬盘安装SUSE Linux10系统(摘)
- V4L2应用程序框架
- elf文件格式学习总结
- SystemVerilog读取文本文件及hash数据初始化
- VC++模式对话框和非模式对话框的步骤
- 无专门对数据进行管理的软件
- Linux USB 详解
- LINUX软件安装之RPM的安装技巧