linux五种IO模型

linux五种IO模型,包括同步模式(阻塞模式、非阻塞模式、多路复用模式、信号驱动模式)和异步模式
在Linux中,对于一次写入IO操作,是将数据拷贝到TCP内核缓冲区;对于一次读取IO的操作,通常包括两个不同阶段:
 (1)等待数据准备好,到达内核缓冲区;
 (2)从内核向进程复制数据。

参考:https://blog.csdn.net/z_ryan/article/details/80873449

1.阻塞式模型
阻塞调用是指调用结果返回之前,当前线程会被挂起。函数只有在得到结果之后才会返回。
send:若TCP内核发送缓冲区已满,则阻塞等待;若未满,则拷贝数据到缓冲区,并立即返回。(数据实际是由内核协议从缓冲区发送到对端)
recv:若TCP内存接收缓冲区没有数据,则阻塞等待;若有数据,则拷贝缓冲区数据到进程空间并立即返回。

2.非阻塞模式
非阻塞调用是指无论是否可以发送成功,都立即返回。linux通过fcntl设置非阻塞模式。
send:无论TCP内核缓冲区是否已满都立即返回,返回值为实际写入缓冲区的数据长度,范围[0,实际传入数据长度]。
recv:无论TCP内核缓冲区是否有数据都立即返回,返回值为实际接收的数据长度,0表示未接收任何数据。


3.多路复用模式
一个进程可以监视多个描述符,一旦某个描述符就绪(一般是读就绪或者写就绪),能够通知程序进行相应的读写操作。多路复用有select和recv两次系统调用,若同时监控的描述符不多,性能没有阻塞模式快。
select:单个进程可监视的fd数量被限制1024,描述符多时效率低。
poll:本质和select没有区别,没有fd数量限制。
epoll(epoll_ctl、epoll_wait):没有fd数量限制,效率提升,不是轮询的方式,不会随着FD数目的增加效率下降。

4.信号驱动模式
信号驱动I/O并不常用,它是一种半异步的I/O模型。在使用信号驱动I/O时,当数据准备就绪后,内核通过发送一个 SIGIO 信号通知应用进程,应用进程就可以开始读取数据了。

5.异步模式
 



 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值