进程间通信方法一:匿名管道
来源:互联网 发布:淘宝房地产拍卖网 编辑:程序博客网 时间:2024/06/05 18:23
进程间通信方法一:匿名管道
系统中的公共资源由操作系统(内核)提供,进程间互相独立,各不干扰。
如果一份资源可被多个进程访问,则被称为临界资源。
临界资源需要被保护,临界资源任意时刻保证只有一个进程在访问,且任何进程访问临界资源时要保持原子性,以原子形式读写,互斥访问。
进程间的的通信方法有多种,这篇博客介绍一下其中的一种通信方式,匿名管道(pipe)。
管道是一种最基本的IPC机制,由 pipe函数创建。
pipe函数调用成功返回0,失败返回-1。
函数原型为: int pipe(int pipefd[2])
匿名管道的特点有:
1.管道常用于有血缘关系的进程(如父子进程、兄弟进程)
2.管道是文件,进程退出时,文件会自动销毁,管道的生命周期随进程终止而消失,即随进程(生命周期)
3.管道内部已经完成同步,保持了数据的一致性
4.管道基于字节流
5.当管道被写满后,写者会一直进行阻塞式等待。
这种管道在通信时可能会发生四种情况
1.读者一直在读,写的停止写入,但是没有关闭描述符
2.写者一直在写,读的停止读出,但是没有关闭描述符
3.写者一直在写,读的停止读出,并且关闭描述符
4.读者一直在读,写的停止写入,并且关闭描述符
0 0
- 进程间通信方法一:匿名管道
- 学习进程间通信 (一)匿名管道通信
- 进程间通信-匿名管道
- 进程间通信 - 匿名管道
- 进程间通信匿名管道
- 进程间通信-匿名管道
- Linux进程间通信::匿名管道实例(一)
- 进程间通信:匿名管道通信
- 进程间通信之匿名管道通信
- 进程通信-匿名管道
- 进程通信 - 匿名管道
- 进程间通信之管道通信(匿名管道)
- 匿名管道--进程间的通信
- 进程间通信-匿名管道
- 通过匿名管道实现进程间通信
- 进程间通信 - 匿名管道实现
- 进程间通信详解 - 匿名管道实现
- 进程间通信——匿名管道
- hibernate 一对多
- 数据库基本概念和操作
- 扩张表空间的三种方法
- 比特币解决方法推荐
- 常见对象-StringBuffer和String的相互转换
- 进程间通信方法一:匿名管道
- Scala中的数组、映射、元组、集合
- 创世纪
- Linux关机重启停机(shutdown reboot halt)流程分析
- tensorflow:fully_connected_feed.py代码详细中文注释
- 模板方法模式【Template Method Pattern】
- 应届生/初级数据库开发笔面试汇总
- 关于main函数的第二个参数
- selenium+testng+gitblit+jenkins+ant自动化测试系列九:ant的build.xml文件详解及运用