【TCP】tcp协议通信中io

阻塞IO

recv,接收数据,若没有,将阻塞,

当对方发数据来后,linux内核缓冲区得到数据,

内核数据复制到recv()调用所在的用户空间,

阻塞解除,进行下一步处理,

非阻塞IO

轮询调用recv函数接收数据,

没有数据,立即返回,然后继续调用,

根据返回值来判定时候读到数据,

这种方式大量消耗CPU,应用范围小,一般和selectIO复用配合使用,

IO复用

select机制,可以轮询多个fd的状态变化,

进而决定recv是否要进行数据的读,而不致像上面两种极端,

但是所轮询的多个fd都没有状态变化,也将阻塞,

同时select也可以设置等待时间,避免干等,

信号驱动IO

建立一个信号,当有数据到来的时候,通知上层应用去读取数据,

这种模型用的较少,信号发送有延迟,处理数据有延迟,内核数据也可能发生变化,

  为什么说信号驱动的延迟大呢?

  因为有数据了,得发送一个信号去通知上层应用,

  通知之后,不一定马上来读取,

  有机会读取了,还得跑过来读

异步IO

异步IO,上层应用提供了一个应用层的缓冲区,

有数据了,内核会主动,,的把数据塞到应用层提供的这个缓冲区,而不用像上面那样有那么的工序去主动地读,不过这个复杂工序你暂时没办法了解很深入,但是可以肯定的是,主动读肯定涉及到很多过程处理,

转载于:https://www.cnblogs.com/itplay/p/11375441.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值