欢迎来到天天文库
浏览记录
ID:3710865
大小:146.61 KB
页数:5页
时间:2017-11-23
《非阻塞 不常用 ,i o多路复用 io多路复用的应用》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、非阻塞不常用,IO多路复用IO多路复用的应用 五种I/O模式:【1】阻塞I/O【2】非阻塞I/O【3】I/O多路复用【4】信号驱动I/O(SIGIO)【5】异步I/O一般来说,程序进行输入操作有两步:1.等待有数据可以读2.将数据从系统内核中拷贝到程序的数据区。对于sock编程来说:第一步:一般来说是等待数据从网络上传到本地。当数据包到达的时候,数据将会从网络层拷贝到内核的缓存中;第二步:是从内核中把数据拷贝到程序的数据区中。阻塞I/O模式//进程处于阻塞模式时,让出CPU,进入休眠状态阻塞I/O模式是最普遍使用的I/O模式。是Linux系统下缺省的IO模式。大部分程序使用的都
2、是阻塞模式的I/O。一个套接字建立后所处于的模式就是阻塞I/O模式。(因为Linux系统默认的IO模式是阻塞模式)对于一个UDP套接字来说,数据就绪的标志比较简单:(1)已经收到了一整个数据报(2)没有收到。而TCP这个概念就比较复杂,需要附加一些其他的变量。一个进程调用recvfrom,然后系统调用并不返回知道有数据报到达本地系统,然后系统将数据拷贝到进程的缓存中。(如果系统调用收到一个中断信号,则它的调用会被中断)我们称这个进程在调用recvfrom一直到从recvfrom返回这段时间是阻塞的。当recvfrom正常返回时,我们的进程继续它的操作。非阻塞模式I/O//非阻塞
3、模式的使用并不普遍,因为非阻塞模式会浪费大量的CPU资源。当我们将一个套接字设置为非阻塞模式,我们相当于告诉了系统内核:"当我请求的I/O操作不能够马上完成,你想让我的进程进行休眠等待的时候,不要这么做,请马上返回一个错误给我。"我们开始对recvfrom的三次调用,因为系统还没有接收到网络数据,所以内核马上返回一个EWOULDBLOCK的错误。第四次我们调用recvfrom函数,一个数据报已经到达了,内核将它拷贝到我们的应用程序的缓冲区中,然后recvfrom正常返回,我们就可以对接收到的数据进行处理了。当一个应用程序使用了非阻塞模式的套接字,它需要使用一个循环来不听的测试是
4、否一个文件描述符有数据可读(称做polling(轮询))。应用程序不停的polling内核来检查是否I/O操作已经就绪。这将是一个极浪费CPU资源的操作。这种模式使用中不是很普遍。例如:对管道的操作,最好使用非阻塞方式!I/O多路复用//针对批量IP操作时,使用I/O多路复用,非常有好。在使用I/O多路技术的时候,我们调用select()函数和poll()函数或epoll函数(2.6内核开始支持),在调用它们的时候阻塞,而不是我们来调用recvfrom(或recv)的时候阻塞。当我们调用select函数阻塞的时候,select函数等待数据报套接字进入读就绪状态。当select函
5、数返回的时候,也就是套接字可以读取数据的时候。这时候我们就可以调用recvfrom函数来将数据拷贝到我们的程序缓冲区中。对于单个I/O操作,和阻塞模式相比较,select()和poll()或epoll并没有什么高级的地方。而且,在阻塞模式下只需要调用一个函数:读取或发送函数。在使用了多路复用技术后,我们需要调用两个函数了:先调用select()函数或poll()函数,然后才能进行真正的读写。多路复用的高级之处在于:它能同时等待多个文件描述符,而这些文件描述符(套接字描述符)其中的任意一个进入读就绪状态,select()函数就可以返回。IO多路技术一般在下面这些情况中被使用:1、
6、当一个客户端需要同时处理多个文件描述符的输入输出操作的时候(一般来说是标准的输入输出和网络套接字),I/O多路复用技术将会有机会得到使用。2、当程序需要同时进行多个套接字的操作的时候。3、如果一个TCP服务器程序同时处理正在侦听网络连接的套接字和已经连接好的套接字。4、如果一个服务器程序同时使用TCP和UDP协议。5、如果一个服务器同时使用多种服务并且每种服务可能使用不同的协议(比如inetd就是这样的)。异步IO模式有:1、信号驱动I/O模式2、异步I/O模式信号驱动I/O模式//自己没有用过。我们可以使用信号,让内核在文件描述符就绪的时候使用SIGIO信号来通知我们。我们将
7、这种模式称为信号驱动I/O模式。为了在一个套接字上使用信号驱动I/O操作,下面这三步是所必须的。(1)一个和SIGIO信号的处理函数必须设定。(2)套接字的拥有者必须被设定。一般来说是使用fcntl函数的F_SETOWN参数来进行设定拥有者。(3)套接字必须被允许使用异步I/O。一般是通过调用fcntl函数的F_SETFL命令,O_ASYNC为参数来实现。虽然设定套接字为异步I/O非常简单,但是使用起来困难的部分是怎样在程序中断定产生SIGIO信号发送给套接字属主的时候,程序处在什么状态。1
此文档下载收益归作者所有