您的位置:首页 > 理论基础 > 计算机网络

网络编程的5个IO模型

2017-05-22 15:04 393 查看


网络编程的5个io模型

据Unix网络编程,Unix主要有阻塞IO、非阻塞IO、信号驱动IO、IO复用、异步IO;前五种都是同步,只有最后一种才是异步IO。
    1、 先贴上Unix网络编程的几张大图:
     同步IO和异步IO的区别就在于:数据拷贝的时候进程是否阻塞!
     阻塞IO和非阻塞IO的区别就在于:应用程序的调用是否立即返回!
     阻塞IO:从图中可以看出进程会一直阻塞,直到数据拷贝完成;



   非阻塞IO:非阻塞IO通过进程反复调用IO函数(多次系统调用,并马上返回);在数据拷贝的过程中,进程是阻塞的;



 信号驱动IO:两次调用,两次返回;



IO复用:主要是select和epoll;对一个IO端口,两次调用,两次返回,比阻塞IO并没有什么优越性;关键是能实现同时对多个IO端口进行监听;



异步IO:数据拷贝的时候进程无需阻塞。

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  网络编程