记linux下IO复用--IO复用的学习

本文详细介绍了Linux中的IO复用,包括堵塞与非堵塞IO的区别,同步与异步IO的特性,并重点讲解了IO复用模型如select、poll和epoll,特别是epoll的三种轮询方式和API函数,以及LT模式和ET模式的工作原理。
摘要由CSDN通过智能技术生成

1.区分堵塞、非堵塞

在一个IO操作过程中,以read为例,会涉及到两个过程:
1.等待数据准备好;
2.将数据从内核拷贝到进程中
这两个阶段是否发生阻塞,将产生不同的效果。

堵塞IO:

进程在请求read阻塞io的数据时,操作需要彻底完成后才返回到用户空间

非堵塞IO:

进程在步骤1不堵塞,如果数据没准备好,read(io操作)函数会立即返回一个状态值反馈给进程,所以对于非阻塞io,可以用一个while循环嵌套read来保证数据被读取。

2.区分同步、异步

同步IO

举个例子,同步IO在执行read函数时,如果有数据可读,进程会等待read函数执行完毕后继续执行接下去的代码。从这个层次来,阻塞IO、非阻塞IO操作、IO多路复用都是同步IO。

异步IO

异步IO操作不会导致请求的进程被blocked。当发出read请求,直接返回,等待read完成后,再通过返回值通知调用进程。

3.IO复用的定义及作用

I/O多路复用是通过一种机制,可以监视多个描述符,一旦某个描述符就绪(一般是读就绪或者写就绪),能够通知程序进行相应的读写操作。常见的IO复用模型有select、poll、epoll三种,IO复用是一种同步IO。

Epoll-IO复用的优势所在ÿ

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值