线程池(ThreadPool)
2010-03-13 13:15
323 查看
总结起来说,线程池有如下的特性:
每个进程有一个单独的池,也只有一个
每个池初始的线程数是相当于处理器的数目
每个池默认的最大线程数是处理器数目的25倍
即便所有的线程都不处于空闲状态,但此时又有新任务过来,也不一定会马上创建新线程,而是按照半秒的周期再决定是否创建新线程
如果达到了最大的线程数,而且没有空闲的情况,那么如果有新任务,就需要等待
.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }
每个进程有一个单独的池,也只有一个
每个池初始的线程数是相当于处理器的数目
每个池默认的最大线程数是处理器数目的25倍
即便所有的线程都不处于空闲状态,但此时又有新任务过来,也不一定会马上创建新线程,而是按照半秒的周期再决定是否创建新线程
如果达到了最大的线程数,而且没有空闲的情况,那么如果有新任务,就需要等待
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading; using Microsoft.Win32; namespace ConsoleApplication1 { class Program { static void Main(string[] args) { int workerThreadCount, completionThreaderCount; //默认为处理器数目,这是为了尽可能少一些线程。我的机器上返回2 ShowMinThread(out workerThreadCount, out completionThreaderCount); //每个进程都有一个线程池。线程池的默认大小为:每个可用处理器 25 个辅助线程(我的机器返回500),再加上 1000 个 I/O 完成线程。 ShowMaxThread(ref workerThreadCount, ref completionThreaderCount); ShowAvailableThread(ref workerThreadCount, ref completionThreaderCount); ThreadPool.SetMaxThreads(20, 20); ShowMaxThread(ref workerThreadCount, ref completionThreaderCount); //在所有线程池线程都分配到任务后,线程池不会立即开始创建新的空闲线程。为避免向线程分配不必要的堆栈空间,线程池按照一定的时间间隔创建新的空闲线程。该时间间隔目前为半秒,但它在 .NET Framework 的以后版本中可能会更改。 Console.Read(); } private static void ShowAvailableThread(ref int c, ref int d) { ThreadPool.GetAvailableThreads(out c, out d); Console.WriteLine(c); Console.WriteLine(d); } private static void ShowMaxThread(ref int c, ref int d) { ThreadPool.GetMaxThreads(out c, out d); Console.WriteLine(c); Console.WriteLine(d); } private static void ShowMinThread(out int c, out int d) { ThreadPool.GetMinThreads(out c, out d); Console.WriteLine(c); Console.WriteLine(d); } } }
.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }
相关文章推荐
- Android 应用开发 之通过AsyncTask与ThreadPool(线程池)两种方式异步加载大量数据的分析与对比
- 实现Spring整合线程池ThreadPoolTaskExecutor
- 线程池 (thread pool) 的类型与实现方式
- Spring中的线程池ThreadPoolTaskExecutor
- 简易线程池Thread Pool
- boost 中使用 线程池threadpool
- ThreadPool(线程池) in .Net(转)
- Android Thread Pool(线程池)
- 线程池-newFixedThreadPool、newCachedThreadPool、
- 多线程编程(3):线程池ThreadPool
- Java 四种线程池newCachedThreadPool,newFixedThreadPool,newScheduledThreadPool,newSingleThreadExecutor
- Android 应用开发 之通过AsyncTask与ThreadPool(线程池)两种方式异步加载大量数据的分析与对比
- 用线程池(Thread Pool)实现异步执行程序
- jetty的线程池实现QueuedThreadPool
- ThreadPool(线程池)
- 关于python线程池threadpool
- ExecutorService常用方法和newFixedThreadPool创建固定大小的线程池
- Extended Thread Pool(可扩展的线程池)
- MinerThreadPool.java 线程池
- newCachedThreadPool线程池