【架构师面试-Java编程基本功-5】-五种IO模型

本文解析了BIO、NIO、AIO、signal blocking I/O和I/O multiplexing五种I/O操作模型,通过钓鱼比喻阐述它们的工作原理。BIO如专注钓鱼者,NIO如兼顾阅读的钓鱼者,AIO则雇佣助手,signal blocking I/O利用铃铛通知,而I/O multiplexing如同时关注多根鱼竿。
摘要由CSDN通过智能技术生成

注意:我这里的用户空间就是应用程序空间

1:阻塞 BIO(blocking I/O)

A 拿着一支鱼竿在河边钓鱼,并且一直在鱼竿前等,在等的时候不做其他的事情,十分专心。只有鱼上钩的时,才结束掉等的动作,把鱼钓上来。

在内核将数据准备好之前,系统调用会一直等待所有的套接字,默认的是阻塞方式。

 2:非阻塞 NIO(noblocking I/O)

B 也在河边钓鱼,但是 B 不想将自己的所有时间都花费在钓鱼上,在等鱼上钩这个时间段中,B 也在做其他的事情(一会看看书,一会读读报纸,一会又去看其他人的钓鱼等),但 B 在做这些事情的时候,每隔一个固定的时间检查鱼是否上钩。一旦检查到有鱼上钩,就停下手中的事情,把鱼钓上来。 B 在检查鱼竿是否有鱼,是一个轮询的过程。

3:异步 AIO(asynchronous I/O)

C 也想钓鱼,但 C 有事情,于是他雇来了 D、E、F,让他们帮他等待鱼上钩,一旦有鱼上钩,就打电话给 C,C 就会将鱼钓上去。

当应用程序请求数据时,内核一方面去取数据报内容返回,另一方面将程序控制权还给应用进程,应用进程继续处理其他事情,是一种非阻塞的状态。

4:信号驱动 IO(signal blocking I/O)

G 也在河边钓鱼,但与 A、B、C 不同的是,G 比较聪明,他给鱼竿上挂一个铃铛,当有鱼上钩的时候,这个铃铛就会被碰响,G 就会将鱼钓上来。

信号驱动 IO 模型,应用进程告诉内核:当数据报准备好的时候,给我发送一个信号,对 SIGIO 信号进行捕捉,并且调用我的信号处理函数来获取数据报。

5:IO 多路转接(I/O multiplexing)

H 同样也在河边钓鱼,但是 H 生活水平比较好,H 拿了很多的鱼竿,一次性有很多鱼竿在等,H 不断的查看每个鱼竿是否有鱼上钩。增加了效率,减少了等待的时间。

IO 多路转接是多了一个 select 函数,select 函数有一个参数是文件描述符集合,对这些文件描述符进行循环监听,当某个文件描述符就绪时,就对这个文件描述符进行处理。

IO 多路转接是属于阻塞 IO,但可以对多个文件描述符进行阻塞监听,所以效率较阻塞 IO 的高。 

如果您觉得文章好看,欢迎点赞,感谢!!☺☻

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不要迷恋发哥

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值