一个用于检查可读性-Read.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
一个用于检查可读性-Read

fd_set参数:一个用于检查可读性(readfds),一个用于检查可写性(writefds),另一个用于例外数据(exceptfds)。从根本上说, fd_set数据类型代表着一系列特定套接字的集合。其中,readfds集合包括符合下述任何一个条件的套接字: ■有数据可以读入。 ■连接已经关闭、重设或中止。 ■假如已调用了listen,而且一个连接正在建立,那么accept函数调用会成功。 writefds集合包括符合下述任何一个条件的套接字: ■有数据可以发出。 ■如果已完成了对一个非锁定连接调用的处理,连接就会成功。 最后,exceptfds集合包括符合下述任何一个条件的套接字: ■假如已完成了对一个非锁定连接调用的处理,连接尝试就会失败。 ■有带外(Out-of-band,OOB)数据可供读取。 用select对套接字进行监视之前,在自己的应用程序中,必须将套接字句柄分配给一个集 合,设置好一个或全部读、写以及例外fd_set结构。将一个套接字分配给任何一个集合后,再 来调用select,便可知道一个套接字上是否正在发生上述的I/O活动。Winsock提供了下列宏操作,可用来针对I/O活动,对fd_set进行处理与检查: ■FD_CLR(s,*set):从set中删除套接字s。 ■FD_ISSET(s,*set):检查s是否set集合的一名成员;如答案是肯定的是,则返回TRUE。 ■FD_SET(s,*set):将套接字s加入集合set。 ■FD_ZERO(*set):将set初始化成空集合。 例如,假定我们想知道是否可从一个套接字中安全地读取数据,同时不会陷于无休止的 “锁定”状态,便可使用FD_SET宏,将自己的套接字分配给fd_read集合,再来调用select。要 想检测自己的套接字是否仍属fd_read集合的一部分,可使用FD_ISSET宏。采用下述步骤,便 可完成用select操作一个或多个套接字句柄的全过程: 1)使用FD_ZERO宏,初始化自己感兴趣的每一个fd_set。 2)使用FD_SET宏,将套接字句柄分配给自己感兴趣的每个fd_set。 3)调用select函数,然后等待在指定的fd_set集合中,I/O活动设置好一个或多个套接字句柄。 select完成后,会返回在所有fd_set集合中设置的套接字句柄总数,并对每个集合进行相应的更新。 4)根据select的返回值,我们的应用程序便可判断出哪些套接字存在着尚未完成(待决) 的I/O操作—具体的方法是使用FD_ISSET宏,对每个fd_set集合进行检查。 5)知道了每个集合中“待决”的I/O操作之后,对I/O进行处理,然后返回步骤1),继续进 行select处理。 select返回后,它会修改每个fd_set结构,删除那些不存在待决I/O操作的套接字句柄。 若WSAWaitForMultipleEvents收到一个事件对象的网络事件通知,便会返回一个值,指 出造成函数返回的事件对象。这样一来,我们的应用程序便可引用事件数组中已传信的事件, 并检索与那个事件对应的套接字,判断到底是在哪个套接字上,发生了什么网络事件类型。 对事件数组中的事件进行引用时,应该用WSAWaitForMultipleEvents的返回值,减去预定义 值WSA_WAIT_EVENT_0,得到具体的引用值(即索引位置)。如下例所示: 知道了造成网络事件的套接字后,接下来可调用WSAEnumNetworkEvents函数,调查发 生了什么类型的网络事件。该函数定义如下: s参数对应于造成了网络事件的套接字。hEventObject参数则是可选的;它指定了一个事件句柄,对应于打算重设的那个事件对象。由于我们的事件对象处在一个“已传信”状态,所以可将它传入,令其自动成为“未传信”状态。如果不想用hEventObject参数来重设事件,那么可使用WSAResetEvent函数,该函数早先已经讨论过了。最后一个参数是lpNetworkEvents,代表一个指针,指向WSANETWORKEVENTS结构,用于接收套接字上发生的网络事件类型以及可能出现的任何错误代码。下面是WSANETWORKEVENTS结构的定义: 创建套接字的时候,假如使用的是socket函数,而非WSASocket函数,那么会默认设置WSA_FLAG_OVERLAPPED标志。成功建好一个套接字,同时将其与一个本地接口绑定到一起后,便可开始进行重叠I/O操作,方法是调用下述的Winsock函数,同时指定一个WSAOVERLAPPED结构(可选): ■WSASend ■WSASendTo ■WSARecv ■WSARecvFrom ■WSAIoctl ■AcceptEx ■

文档评论(0)

teda + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档