多线程实现并发TCP服务器.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文档。上传文档
查看更多
多线程实现并发TCP服务器

阻塞方式下读取或者写入函数将一直等待,而非阻塞方式下,读取或者写入函数会立即返回一个状态值。 1.输入操作:?recv()、recvfrom()、WSARecv()和WSARecvfrom()函数。以阻塞套接字为参数调用该函数接收数据。如果此时套接字缓冲区内没有数据可读,则调用线程在数据到来前一直睡眠。 ? ? 2.输出操作:?send()、sendto()、WSASend()和WSASendto()函数。以阻塞套接字为参数调用该函数发送数据。如果套接字缓冲区没有可用空间,线程会一直睡眠,直到有空间。 ? ? 3.接受连接:accept()和WSAAcept()函数。以阻塞套接字为参数调用该函数,等待接受对方的连接请求。如果此时没有连接请求,线程就会进入睡眠状态。 ? ?4.外出连接:connect()和WSAConnect()函数。对于TCP连接,客户端以阻塞套接字为参数,调用该函数向服务器发起连接。该函数在收到服务器的应答前,不会返回。这意味着TCP连接总会等待至少到服务器的一次往返时间。 * | ? 2011 Lenovo Lenovo Confidential 彭 丹 多线程并发服务器 知识点回顾 1. 多线程 2. Socket 1. 多线程 1. 概念 线程是程序中一个单一的顺序控制流程.在单个程序中同时运行多个线程完成不同的工作,称为多线程。 2. 共享资源 一个进程的所有线程共享进程的地址空间和全局变量 3. 函数 int?pthread_create(pthread_t?*tidp,const?pthread_attr_t?*attr, (void*)(*start_rtn)(void*),void?*arg); 编译链接参数 -pthread 2.Socket 建立TCP连接流程 代码演示 1TCP-简单收发 本章知识点 1.并发 2. Linux下tcp并发服务器的几种设计模式 3.阻塞? 4. 如何实现client和server实时收发数据 5. 如何实现TCP server同时和多个客户端相连 6. 如何实现TCP多个客户端互相通信 1. 并发 概念 当有多个线程在操作时,如果系统只有一个CPU,则它根本不可能真正同时进行一个以上的线程,它只能把CPU运行时间划分成若干个时间段,再将时间 段分配给各个线程执行,在一个时间段的线程代码运行时,其它线程处于挂起状。这种方式我们称之为并发(Concurrent)。 3. Linux下tcp并发服务器的几种设计模式 多进程模式 ??? accept返回成功时候,就为这一个连接fork一个进程,专门处理这个连接上的数据收发,等这个连接处理结束之后就结束这个进程。 ??? 优点: ??????? 编程相对简单,不用考虑线程间的数据同步等。 ??? 缺点: ??????? 资源消耗大。启动一个进程消耗相对比启动一个线程要消耗大很多,同时在处理很多的连接时候需要启动很多的进程多去处理,这时候对系统来说压力就会比较大。另外系统的进程数限制也需要考虑。 ??? 应用: ??????? 在客户端数据不多的时候使用很方便,比如小于10个客户端。 Linux下tcp并发服务器的几种设计的模式 多线程模式 ??? 类似多进程方式,但是针对一个连接启动一个线程。 ??? 优点: ??????? 相对多进程方式,会节约一些资源,会更加高效一些。 ??? 缺点: ??????? 相对多进程方式,增加了编程的复杂度,因为需要考虑数据同步和锁保护。另外一个进程中不能启动太多的线程。在Linux系统下线程在系统内部其实就是进程,线程调度按照进程调度的方式去执行的。 ??? 应用: ?????? 类似于多进程方式,适用于少量的客户端的时候。 Linux下tcp并发服务器的几种设计的模式 ?select + 多线程 模式 ??? 有一个线程专门用于监听端口,accept返回之后就把这个描述符放入 描述符集合 fd中,一个线程用select去轮训描述符集合,在有数据的连接上接收数据,另外一个线程专门发送数据。当然也可以接收和发送用一个线程。描述符可以设置成非阻塞模式,也可以设置成阻塞模式。通常连接设置成非阻塞模式,发送线程独立出来。 ??? 优点: ???????? 相对前几种模式,这种模式大大提高了并发量。 ??? 缺点: ???????? 系统一般实现描述符集合是采用一个大数组,每次调用select的时候都会轮询这个描述符数组,当连接数很多的时候就会导致效率下降。连接数在1000以上时候效率会下降到不能接受。 应用: ???????? 目前windows 和一般的Unix上的tcp并发都采用select方式,应该说应用还是很广泛的。 Li

文档评论(0)

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

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

1亿VIP精品文档

相关文档