线程池是什么,线程池及其原理
发布时间:2020-12-15 04:52:59 所属栏目:安全 来源:网络整理
导读:学习线程时,我们描述了一个多线程的 Web 服务器,每当服务器接收到一个请求时,它都会创建一个单独线程来处理请求。虽然创建一个单独线程肯定优于创建一个单独进程,但是多线程服务器仍然有些潜在的问题。 第一个问题是创建线程所需的时间多少,以及线程在完
学习线程时,我们描述了一个多线程的 Web 服务器,每当服务器接收到一个请求时,它都会创建一个单独线程来处理请求。虽然创建一个单独线程肯定优于创建一个单独进程,但是多线程服务器仍然有些潜在的问题。 第一个问题是创建线程所需的时间多少,以及线程在完成工作之后会被丢弃的事实。第二个问题更为麻烦,如果允许所有并发请求都通过新线程来处理,那么我们没有限制系统内的并发执行线程的数量。无限制的线程可能耗尽系统资源,如 CPU 时间和内存。解决这个问题的一种方法是使用线程池。 线程池的主要思想是:在进程开始时创建一定数量的线程,并加到池中以等待工作。当服务器收到请求时,它会唤醒池内的一个线程(如果有可用线程),并将需要服务的请求传递给它。一旦线程完成了服务,它会返回到池中再等待工作。如果池内没有可用线程,那么服务器会等待,直到有空线程为止。 线程池具有以下优点:
池内线程的数量可以通过一些因素来加以估算,如系统 CPU 的数量、物理内存的大小和并发客户请求数量的期望值等。更为高级的线程池架构可以根据使用模式动态调整池内线程数量。这类架构在系统负荷低时,提供了较小的池,从而减低内存消耗(如 Apple的大中央调度)。 Windows API 提供了与线程池有关的多个函数。使用线程池 API 类似于通过函数 Thread_Create() 来创建线程,参见《线程库》一节。这里,定义一个函数,以作为单独线程来运行。这样一个函数如下所示: DWORD WINAPI PoolFunction(AVOID Param) { /* * this function runs as a separate thread. */ }PoolFunction() 的指针会被传给线程池 API 中的一个函数,池内的某个线程会执行该函数。线程池 API 的一个这种函数为 QueueUserWorkItem(),它需要三个参数:
调用这个函数的示例如下: QueueUserWorkItem(&PoolFunction,NULL,0);这让线程池的一个线程代替程序员来调用 PoolFunction()。这里,我们没有传递参数给 PoolFunction()。由于标志设为 0,因此针对线程池如何创建线程,没有特殊指令。 Windows 线程池 API 还包括可周期性地调用函数,或在一个异步 I/O 请求结束时调用函数。Java API 的 java.util.concurrent 也提供了线程池支持。(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- 4、Angular JS 学习笔记 – 创建自定义指令 [翻译中]
- AngularJS和contentEditable双向绑定不能按预期工作
- 如何在scala中使用flink fold函数
- 使用命令wsimport构建WebService客户端
- 大数据学习第3天---------------------多台机器,利用软连接
- Bootstrap-IE6
- 使用Bash下载并在wordpress wp-config.php中插入盐串
- 我在AngularJS中的双向无限滚动有什么问题?
- Bootstrap 中下拉菜单修改成鼠标悬停直接显示 <font co
- unix – 为什么行#!/ bin / ksh是shell脚本中的第一行