Linux05(管道)

#技术笔记

1.管道

命名管道 是一种特殊的文件 ,又称FIFO,Linux 中用mkfifo name.pipe 命令来创建;本质只是一个数据流或缓冲区,管道允许一个进程的输出作为另一个进程的输入,是Linux系统中一种重要的实现进程间通信的机制;使用命名管道注意,必须读端写端同时打开,不然会阻塞。

管道的读空阻塞 ,和写满阻塞 ,这两个含义跟其命名一样,当管道无数据,读操作就会阻塞 ,管道数据满了,写就会阻塞;命名管道是一种半双工通信,一般一端写,另一端读,不是同时的。

在管道的操作中,如果写端关闭,读端可以继续从管道读数据,有剩余数据就读,没有数据就返回 0;如果读端关闭,写端继续写数据的话, 就会触发SIGPIPE信号,导致进程异常终止。所以一般用两个管道 构建两个进程的全双工通信。

2.I/O多路复用

操作系统允许单个进程或线程同时监视多个文件描述符的一种技术。select 是实现IO多路复用的一种方式,还有其他的 poll,epoll

select 就是同时检查多个文件描述符的一种技术,文件描述符可用,select就会阻塞,read(STDIN_FILENO,...) 当文件描述符 0 可用,即(STDIN_FILENO) 可用,其实就是键盘中有数据; 其最基本的原理就是把要监视的文件描述符构建成一个文件描述符的监听集合,这个集合交给 select ,slect 促成操作系统内核来轮询监听文件描述符这个集合,直到监听集合中至少有一个文件就绪,这样,这一次 slect 监听就结束了,并携带就绪的文件描述符集合返回。

相关推荐
闪电悠米1 分钟前
黑马点评-秒杀优化-04_lua_and_db_fallback
服务器·开发语言·网络·数据库·缓存·junit·lua
豆瓣鸡5 分钟前
Docker快速入门
运维·docker·容器
Shadow(⊙o⊙)6 分钟前
进程间通信0.0-pipe()匿名管道,详细分析进程池调度队列执行逻辑,进程池模拟实现。
linux·运维·服务器·开发语言·c++
指尖的爷13 分钟前
C++头文件的作用
开发语言·c++
keykey6.13 分钟前
反向传播与梯度下降:神经网络如何学习
开发语言·人工智能·深度学习·机器学习
CQU_JIAKE15 分钟前
6.6aaaaaa
linux·运维·服务器
Apibro19 分钟前
【Linux】Qt Creator 中文输入法
linux·qt
Jun62620 分钟前
QT(5)-第三方日志系统
开发语言·数据库·qt
冰暮流星23 分钟前
javascript建立对象之构造函数
开发语言·javascript·ecmascript
smallswan27 分钟前
第十四 算数运算
linux·服务器·前端