时间:2023-4-22来源:本站原创作者:佚名
北京白癜风医院 https://wapjbk.39.net/yiyuanfengcai/ys_bjzkbdfyy/

  高性能编程开发是目前大多数软件开发项目都具备的一个开发需求,而本文我们就通过案例分析来了解一下,常见的高性能编程开发方案都有哪些。

  1、IO多路复用模型

  -思路:单进程(非多线程)调用select()函数来处理多个连接请求。

  -优点:单进程(非多线程)可支持同时处理多个网络连接请求。

  -缺点:大并发为个,当并发数较大时,其处理性能很低。

  2、多进程模型

  -思路:当连接请求过来时,主进程fork产生一个子进程,让子进程负责与客户端连接进行数据通信,当客户端主动关闭连接后,子进程结束运行。

  -优点:模式简单,易于理解;连接请求很小时,效率较高。

  -缺点:当连接请求过多时,系统资源很快被耗尽。比如:当连接请求达到10k时,难道要启动10k个进程吗?

  3、多线程模型

  -思路:先启动多个工作线程,而主线程负责接收客户端连接请求,工作线程负责与客户端通信;当连接请求过来时,ACCEPT线程将sckid放入一个数组中,工作线程中的空闲线程从数组中取走一个sckid,对应的工作线程再与客户端连接进行数据通信,当客户端主动关闭连接后,此工作线程又去从指定数组中取sckid,依次重复运行。

  -优点:拥有方案2)的优点,且能够解决方案2)的缺点。

  -缺点:不能支持并发量大的请求和量稍大的长连接请求。


转载请注明原文网址:http://www.gzdatangtv.com/hjpz/hjpz/18281.html
------分隔线----------------------------