IO模型一网络IO

我们致力研究的IO模型都是网络IO

五种IO模型

        blocking IO           阻塞IO

        nonblocking          非阻塞IO

        IO multiplexing      IO多路复用

        signal driven IO    信号驱动IO(不常用)

        asynchronous IO  异步IO

常见的网络阻塞状态

accept        recv        recvfrom

阻塞IO

非阻塞IO

阻塞 I/O 与非阻塞 I/O 的区别

  • 阻塞 I/O:当应用程序调用一个 I/O 操作(如读取或写入)时,如果数据还没有准备好,应用程序会被阻塞(即挂起),直到数据准备好或操作完成。

  • 非阻塞 I/O:当应用程序调用一个 I/O 操作时,如果数据还没有准备好,系统会立即返回一个错误或特殊值(如 EAGAIN 或 EWOULDBLOCK),而不是阻塞应用程序。应用程序可以继续执行其他任务,稍后再尝试进行 I/O 操作

 非阻塞 I/O 的工作原理

  • 系统调用:应用程序通过系统调用(如 readwriterecvsend 等)发起 I/O 操作。

  • 立即返回:如果数据还没有准备好,系统调用会立即返回一个错误码(如 EAGAIN 或 EWOULDBLOCK),表示当前不可进行 I/O 操作。

  • 轮询:应用程序可以通过轮询(polling)机制不断检查 I/O 操作的状态,直到数据准备好。

  • 事件驱动:更高效的方式是使用事件驱动模型(如 selectpollepoll 或 kqueue),应用程序可以注册感兴趣的 I/O 事件,当事件发生时,系统会通知应用程序。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值