首页
学习
活动
专区
圈层
工具
发布

Linux select poll源码剖析

在读select、poll源码前,需要先了解的知识点: 等待队列 文件系统(主要是进程的打开文件描述符表以及struct file) poll机制 资源注册监听poll() -> poll_wait(...select()/poll()调用对应一个struct poll_wqueues 一个监听事件对应一个struct poll_table_entry Common poll机制是所有多路转接的共性;调用控制块.../* * Structures and helpers for sys_poll/sys_poll */ struct poll_wqueues { poll_table pt; struct...实际linux内核设计: * 每个wait_queue_t的private字段指向同一个poll_wqueues,然后 * 共用的poll_wqueues中保存了指向调用进程...被封装在了poll_wqueues结构体中,以便之后向资源 * 注册监听的时候,能够用poll_table得到对应的poll_wqueues * * 初始化poll_wqueues

3.6K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    【Linux网络】多路转接:select、poll、epoll

    1、select 在Linux中,常见的多路转接/复用有 select、poll 和 epoll 。...2、poll 和 select 一样,poll的定位也是对多个 fd IO事件的等待机制,达到事件派发的目的。...3、epoll epoll 是 Linux 系统中一种高效的 I/O 事件通知机制,常用于处理大量文件描述符的 I/O 事件,特别适合高并发场景。...3.1 epoll_create int epoll_create(int size); 在内核中创建一个 epoll 模型,并返回文件描述符用于后续的操作; 自从 linux2.6.8 之后,size...) 如果函数调用成功,返回对应 I/O 上已准备好的文件描述符数目,如返回 0 表 示已超时,返回小于 0 表示函数失败 3.4 epoll 工作原理 当进程调用 epoll_create 方法时,Linux

    75910

    Linux学习系列六:操作GPIO

    1 引言 学习单片机的第一个例子通常都是点亮LED灯,对于Linux应用,我们也从LED入手,我就记得自己刚开始学的时候查了好多资料才勉强能控制一个灯亮,当时就感受到了Linux和单片机裸机有很大的差异...2.2.软件 1)需要在上一篇《Linux学习系列五:Nand Flash根文件系统制作》的基础上改动下Linux内核配置,生成新的970uimage并烧写到板子里。...2)先使用我们之前的交叉工具链去编译上述代码 arm-none-linux-gnueabi-gcc gpio_demo.c -o gpio_demo 将生成的gpio_demo放到板子里去运行,提示如下错误...3)使用和板子里自带文件系统匹配的交叉工具链来重新编译 arm-linux-gcc gpio_demo.c -o gpio_demo 这时它会报一个错误: ?...再次将gpio_demo放到板子上,运行,就不再报错了,可以看到LED D3灯在不断的闪烁。 5 结束语 本篇为大家介绍了Linux下GPIO的使用,同时也穿插着介绍shell脚本的些许知识。

    3.9K20

    【Linux】高级IO --- 多路转接,select,poll,epoll

    而此时走过来一个李四,李四这名少年也很喜欢钓鱼,但李四和张三不一样,李四左口袋装着《Linux高性能服务器编程》,右口袋装着一本《算法导论》,左手拿手机,右手拿了一根鱼竿,李四拿了钓鱼凳坐下之后,李四就开始钓鱼了...在这里额外补充一下,linux命令行中表示输入结束的快捷键是ctrl+d,当此热键被用户按下后,代表0号文件描述符写端关闭,此时读端会读到0,read会返回0值,此时进程除了输出提示信息"read file...虽然说epoll是作了改进的poll,但在接口的使用和底层实现上,epoll和poll天差地别,在linux内核2.5.44版本时,就引入了epoll接口,而现在主流的linux内核版本已经是3点几了。...模型其实也是一个struct file结构体,所以epoll_create创建epoll模型成功后,会返回一个文件描述符,而epoll_create的size参数早在内核版本2.6以后就已经被忽略了,在早期的linux...select优点: (1)能够同时监听多个文件描述符,使得一个进程或线程能够同时管理多个IO操作,提升IO的效率 (2)select 是一个跨平台的系统调用,几乎在所有主流操作系统上都得到支持,包括 Linux

    97430

    【Linux网络编程】多路转接IO(一)select,poll

    使用fd_set位图管理 FD 支持跨平台(Linux/Windows) 最大 FD 数受限(通常 1024) 每次调用需重新设置 FD 集合 5,select缺点 每次调用 select...poll并没有最大的数量限制(但是数量过大后,性能也会下降) Linux 专有(Windows 不支持) 4,poll的缺点 和select一样,poll返回后,需要轮询pollfd来获取就绪的文件描述符...实现多路转接,仓库连接: Poll_Server · 小鬼/linux学习 - 码云 - 开源中国 总结 二者对比 特性 Select Poll 最大 FD 数 受限(FD_SETSIZE) 无限制 性能...(FD 量大时) O(n) 扫描 O(n) 扫描 事件类型 仅读/写/异常 更丰富(POLLRDNORM 等) 平台支持 跨平台 Linux 专用 FD 重用 每次需重置 fd_set 可复用 pollfd...数组 使用建议: Select:FD 数量少(<1024),需跨平台 Poll:FD 数量多,仅需支持 Linux 注意:两种模型都采用 水平触发(LT) 模式,即只要 FD 处于就绪状态

    10410
    领券