I/O模型中同步/异步、阻塞/非阻塞 例子解析及定义描述

例子解析

老张(–进程)爱喝茶,废话不说,煮开水(–需要的数据)。 出场人物:老张,水壶两把(普通水壶,简称水壶;会响的水壶,简称响水壶)。
1 老张把水壶放到火上,立等水开。(同步阻塞) 老张觉得自己有点傻
2 老张把水壶放到火上,去客厅看电视,时不时去厨房看看水开没有。(同步非阻塞) 老张还是觉得自己有点傻,于是变高端了,买了把会响笛的那种水壶。水开之后,能大声发出嘀~~~~的噪音。
3 老张把响水壶放到火上,立等水开。(异步阻塞) 老张觉得这样傻等意义不大
4 老张把响水壶放到火上,去客厅看电视,水壶响之前不再去看它了,响了再去拿壶。(异步非阻塞) 老张觉得自己聪明了。

所谓同步异步,只是对于水壶而言。 普通水壶,同步;响水壶,异步。 虽然都能干活,但响水壶可以在自己完工之后,提示老张水开了。这是普通水壶所不能及的。 同步只能让调用者去轮询自己(情况2中),造成老张效率的低下。

所谓阻塞非阻塞,仅仅对于老张而言。 立等的老张,阻塞;看电视的老张,非阻塞。 情况1和情况3中老张就是阻塞的,媳妇喊他都不知道。虽然3中响水壶是异步的,可对于立等的老张没有太大的意义。所以一般异步是配合非阻塞使用的,这样才能发挥异步的效用。

定义描述

同步阻塞I/O是指当进程调用某些设计I/O操作的系统调用或库函数时,比如accept()、send()、recv()等,进程边暂停下来,等待I/O操作完成后在继续运行。在同步阻塞I/O中,进程实际上等待的时间可能包括两部分:等待数据的就绪、等待数据的复制。

同步非阻塞I/O结合反复轮询来查询数据是否就绪,防止进程被阻塞,最大的好处就是可以在一个进程中同时处理多个I/O操作,但是反复轮询会浪费大量的CPU时间。–等待I/O数据时可以做别的事情(不阻塞当前进程)

多路I/O就绪通知,提供了大量文件描述符就绪检查的高性能方案,允许进程通过一种方法来同时监视所有文件描述符,并可以快速获得所有就绪的文件描述符,然后只针对这些文件描述符进行数据访问。实现方法:select、poll、epoll。

内存映射(Memory Mapping),Linux内核提供一种访问磁盘文件的特殊方式,它可以将内存中某块地址空间和我们要指定的磁盘文件相关联,从而把我们对这块内存的访问转换为对磁盘文件的访问。

直接I/O,Linux在open()系统调用中增加参数选项O_DIRECT,用它打开的文件可以绕过内核缓冲区直接访问,这样便有效避免了CPU和内存的多余时间开销。

sendfile可以将磁盘文件的特定部分直接传输到代表客户端的socket描述符,加快了静态文件的请求速度,同时也减少了CPU和内存的开销。

异步I/O,当前用户态进程调用库函数访问文件时,进行必要的快速注册,比如进入读写操作队列,然后函数马上返回,这样进程在发起I/O操作后继续运行,让CPU处理和I/O操作得到更好的并行。

区别

阻塞和非阻塞是指当前进程访问的数据尚未就绪时,进程是直接返回还是等待就绪。

同步和异步是指访问数据的机制,同步一般指主动请求并等待I/O操作完毕的方式,当数据就绪后在读写的时候必须阻塞;
异步则是主动请求数据后便可以继续处理其他任务,随后等待I/O操作完毕的通知,这可以使进程在数据读写时也不发生阻塞。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值