线程池(Thread Pooling),译自MSDN
来源:互联网 发布:水质监测数据指标 编辑:程序博客网 时间:2024/05/16 07:14
线程池(Thread Pooling)
有许多应用线程的程序在等候事件的休眠状态中消耗了大量时间,Other threads may enter a sleeping state only to be awakened periodically to poll for a change or update status information. Thread pooling enables you to use threads more efficiently by providing your application with a pool of worker threads that are managed by the system. 至少一个线程监控着线程池中排列的所有wait操作状态。当一个等候操作执行完毕,线程池中一个worker线程就会执行相应的callback函数。
你也可以把一些不需要wait操作的工作项添加到线程池中。要请求线程池中一个线程可以处理一个工作项的话,可以调用QueueUserWorkItem function. 该函数需要一个线程被选中时需要执行的函数作为参数。排队候,就没有办法撤销一个工作了。
Timer-queue timers and registered wait operations 同样使用线程池. 他们的回调函数被排列到线程池中,你也可以通过 BindIoCompletionCallback 函数post异步I/O操作。异步I/O完成时,就会被线程池中一个线程执行callback函数。
线程池是在第一次调用QueueUserWorkItem or BindIoCompletionCallback时创建的,或者一个timer-queue timer or registered wait operation queues a callback function.默认情况下,线程池中可创建的线程数为500,每个线程应用默认栈大小并按默认优先级执行。
线程池中有两种类型的worker线程: I/O and non-I/O,I/O worker线程wait时有一个alertable wait状态,排队到I/O worker threads中的工作项可看为异步过程调用 (APC).
A non-I/O worker thread waits on I/O completion ports,使用非I/O worker threads比使用I/O worker threads更有效率些。一次,你应该尽可能的使用非I/O worker threads。 如果仍有异步I/O请求未完成, I/O及non-I/O worker threads都不会exit。两种类型的线程都可被用来发起asynchronous I/O completion requests. 然而,如果异步I/O请求完成需要花费很长时间,就应当避免放置到非I/O worker threads中。
要使用线程池,调用的工作项及所有函数必须保证是线程池安全的.安全的函数不应该假定其执行线程是dedicated or persistent的。通常情况下应当避免使用 thread local storage ,并避免把一个需要持久稳定线程的异步调用排队,如RegNotifyChangeKeyValue 函数。然而这些函数可以利用QueueUserWorkItem 的WT_EXECUTEINPERSISTENTTHREAD选项排队为一个持久稳定的worker thread。
注意:线程池不适合于single-threaded apartment (STA) 模式。
- 线程池(Thread Pooling),译自MSDN
- 线程池(Thread Pooling)
- 使用线程池 Thread Pooling
- 线程池(翻译自MSDN)
- VC中使用系统提供的线程池(Thread Pooling)
- .NET多线程同步方法详解(七):线程池(Thread Pooling)
- Spring中的定时调度(Scheduling)和线程池(Thread Pooling)
- NET多线程同步方法详解(七):线程池(Thread Pooling)
- Spring中的定时调度(Scheduling)和线程池(Thread Pooling)
- Spring中的定时调度(Scheduling)和线程池(Thread Pooling)
- Spring中的定时调度(Scheduling)和线程池(Thread Pooling)
- Spring中的定时调度(Scheduling)和线程池(Thread Pooling)
- Chapter 23. Spring中的定时调度(Scheduling)和线程池(Thread Pooling)
- 如何创建和终止线程(转载自MSDN)
- Thread Pooling(收藏)
- AOP(转自MSDN)
- 预防SQL注射攻击(译自MSDN)
- TCP传输小数据包效率问题(译自MSDN)
- 菜鸟宝典 数码相机选购入门手册(之二)
- vss 命令行执行相关操作搜集整理
- 什么是闪光灯
- 菜鸟宝典 数码相机选购入门手册(之三)
- 菜鸟宝典 数码相机选购入门手册(之四)
- 线程池(Thread Pooling),译自MSDN
- windows 下监测TCP/IP通信
- 开张了
- 遇雨
- 内存分配
- 什么是镜头性能
- 使用.NET CF开发Smartphone应用程序 FAQ
- Armadillo 4.20 Standard+Debug Blocker unpacking
- 心情还是不太好