非阻塞socket.pptVIP

  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文档。上传文档
查看更多
非阻塞socket.ppt

非阻塞socket 阻塞模式 是socket的缺省方式,也是最常用的方式,即调用结果返回之前,函数阻塞,当前线程会被挂起,suspend。 可能造成阻塞的函数有:connect()、accept()、读写函数、gethostbyname()等。 再探send和recv send和recv是socket编程中两个核心的函数。 send表示发送数据,其实际上比不是直接将数据发送出去,而是将数据先发送到系统对应的socket的缓冲区,在由系统使用tcpip协议进行发送。此时send返回的结果只是表明是否成功发送到系统的缓冲区。 同样recv函数也是从系统的对应的socket缓冲区读取数据,而该缓冲区中的数据也是由协议保证的。如果该缓冲区没有数据,将区别对待:如果对应的socket是阻塞的,则recv工作在阻塞模式,将一直等到缓冲区中有数据才返回,否则会一直挂 起。 非阻塞模式 非阻塞和阻塞的概念相对应,指在不能立刻得到结果之前,该函数不会阻塞当前线程,而会立刻返回。 如果指定非阻塞模式,程序调用可能造成阻塞的函数时,如果会发生阻塞,这些函数返回-1并将errno设置为EAGAIN或EWOULDBLOCK,程序可继续向下运行。可能阻塞的函数对应的任务完成,则再次调用该函数时就返回0表示运行结束。 fcntl函数 函数fcntl()针对(文件)描述符提供控制。若要改变阻塞模式,可如下调用: 非阻塞I/O:可将cmd设置为F_SETFL,将lock设置为O_NONBLOCK。 异步I/O:可将cmd设置为F_SETFL,将lock设置为O_ASYNC。 所需头文件 #include fcntl.h 函数原型 int fcntl(int fd, int cmd, ...); 函数传入值 cmd F_DUPFD:复制一个现有的描述符 F_GETFD或F_SETFD:获得/设置文件描述符标记 F_GETFL或F_SETFL:获得/设置文件状态标记 F_GETOWN或F_SETOWN:获得/设置异步I/O所有权 F_GETLK,F_SETLK或F_SETLKW:获得/设置记录锁 第三个参数 可选 函数返回值 成功:依据cmd不同 出错:-1 非阻塞模式流程 server while (true) if 有新连接 { 建立并记录该新连接; for (所有的有效连接){ if 该连接中有字符可读 { 读入字符串; for (所有其他的有效连接) { 将该字符串发送给该连接; } } } } client while (true){ if (与server的连接有字符可读) { 从该连接读入; 输出到标准输出上去; } if (标准输入可读) { 从标准输入读入; 发送到与server的连接中去. } } 轮询 非阻塞模式可以避免程序死锁,但是需要程序不断检查各个可能阻塞的函数的状态,当一个应用程序使用了非阻塞模式的套接字,它需要使用一个循环来不听的测试是否一个文件描述符有数据可读(称做轮询,polling)。 分析上面的程序可以知道, 不管是 server 还是 client, 它们都不停的轮流查询各个文件描述符, 一旦可读就读入并进行处理。 应用程序不停的polling内核来检查是否I/O操作已经就绪,对系统资源的消耗非常大。server 或者 client 单独执行时,CPU 资源的 98% 左右都被其占用。这将是一个极浪费CPU资源的操作,因此实际开发中基本不使用。 I/O多路复用 虽然我们不希望在某一个用户没有反应时阻塞其他的用户,但我们却应该在没有任何用户有反应的情况之下停止程序的运行,让出抢占的系统资源,进入阻塞状态。 使用select()、poll()等函数实现对多个socket的同步I/O操作。它能同时等待多个socket描述符,而这些socket描述符其中的任意一个进入读就绪/写就绪/出错状态,select()函数就可以返回。 I/O多路复用 select函数 select 方法中, 所有文件描述符都是阻塞的。使用 select判断一组文件描述符中是否有一个可读(写), 如果没有就阻塞, 直到有一个的时候就被唤醒 所需头文件 #include sys/select.h 函数原型 int select(int maxfdp,fd_set *readfds,fd_set *writefds ,fd_set *errorfds,struct timeval *timeout); 函数传入值 maxfdp:集合中所有文件描述符的范围,即所有文件描述符的

文档评论(0)

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

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

版权声明书
用户编号:5212202040000002

1亿VIP精品文档

相关文档