Chinaunix首页 | 论坛 | 博客
  • 博客访问: 70356
  • 博文数量: 29
  • 博客积分: 98
  • 博客等级: 民兵
  • 技术积分: 160
  • 用 户 组: 普通用户
  • 注册时间: 2011-12-02 00:18
文章分类
文章存档

2012年(13)

2011年(16)

我的朋友

分类:

2011-12-30 22:13:28

原文地址:关于网络IO的理解 作者:unixhero

IO根据对IO的调度方式分为阻塞IO、非阻塞IO、IO复用、信号驱动IO、异步IO。
IO操作整个流程分为可操作判断和实际IO操作两个区间,我们可以称之为两个半程,前半程判断是否可操作,后半程实际操作,其中阻塞IO、非阻塞IO、IO复用、信号驱动IO因为其实际的IO操作是同步阻塞的,所以一般把他们归为同步IO,异步IO的实际IO操作是在独立的线程中完成的,所以称为异步IO。

阻塞IO:服务阻塞在数据接收操作上,直到客户端数据到达并拷贝到本地进程数据区,全程阻塞。

非阻塞IO:服务通过select操作轮询数据是否可读,一旦可读则阻塞的读取数据到本地进程数据区,属于前半程轮询,后半程阻塞模式。

IO复用:同样分为前半程(是否可读)和后半程(实际读取),前半程阻塞(Select阻塞),但只要有一个
IO套接字可用则启动后半程读取进程。

信号驱动IO:同样也分为前后半程,前半程是一个异步机制,注册一个信号驱动事件,在数据可读的时候通过SIGIO信号驱动后半程的触发,其和IO复用的区别在于前半程是一个信号驱动机制。

异步IO:调用IO时提供回调函数,IO作为独立线程完成实际读取及准备工作,到数据复制到本地数据区后通过回调函数调用原调用者进行处理。
阅读(859) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~