.NET线程池ThreadPool.QueueUserWorkItem

概述

ThreadPool.QueueUserWorkItem 是 .NET 中用于将工作项排队到线程池执行的方法,它通过重用现有线程来优化性能,避免频繁创建和销毁线程的开销。

方法定义

命名空间:System.Threading

程序集:System.Threading.ThreadPool.dll

核心功能:将指定方法异步执行,由线程池线程调度 。

重载形式

‌无参数‌

csharp 复制代码
public static bool QueueUserWorkItem(WaitCallback callback)

参数:callback(WaitCallback委托,表示要执行的方法)

返回:true(成功排队),若失败抛出NotSupportedException 。 ‌

‌带参数‌

csharp 复制代码
public static bool QueueUserWorkItem(WaitCallback callback, object state)

参数:state(传递给回调方法的数据对象)

csharp 复制代码
 
ThreadPool.QueueUserWorkItem(ThreadProc, "参数");
private void ThreadProc(object state) { Console.WriteLine(state); }
 

实例

csharp 复制代码
using System;
using System.Threading;

class ThreadPoolExample
{
    static void Main(string[] args)
    {
        // 使用无参重载
        ThreadPool.QueueUserWorkItem(DoWorkWithoutState);
        
        // 使用带状态对象的重载,传递一个字符串
        ThreadPool.QueueUserWorkItem(DoWorkWithState, "Hello from state object");
        
        // 主线程等待一段时间,确保线程池任务有机会执行
        Thread.Sleep(2000);
        Console.WriteLine("主线程结束。");
    }
    
    // 无状态参数的方法
    static void DoWorkWithoutState(object state)
    {
        Console.WriteLine($"无状态任务在线程 {Thread.CurrentThread.ManagedThreadId} 中执行。");
    }
    
    // 带状态参数的方法
    static void DoWorkWithState(object state)
    {
        string message = state as string;
        Console.WriteLine($"带状态任务在线程 {Thread.CurrentThread.ManagedThreadId} 中执行,状态信息:{message}");
    }
}

与 Thread 的性能区别

线程管理方式‌

‌Thread‌:每次调用 new Thread().Start() 都会创建一个新的操作系统线程。

‌ThreadPool‌:利用已创建的空闲线程执行任务,没有空闲线程时才排队等待,不会盲目持续创建新线程。

‌资源开销‌

‌Thread‌:在高请求量场景下,频繁创建新线程会导致 CPU 不堪重负。

‌ThreadPool‌:通过线程复用显著降低资源消耗,但过多的线程任务仍会占用较多资源。

‌适用场景‌

‌Thread‌:适合需要长时间运行或需要精细控制线程行为的任务。

‌ThreadPool‌:更适合执行时间较短、数量较多的后台任务。

‌性能优势‌

线程池通过为应用程序提供一个由系统管理的辅助线程池,使您可以更为有效地使用线程。当有等待操作完成时,线程池中的辅助线程就会执行对应的回调函数。

相关推荐
虹科网络安全15 小时前
艾体宝干货|数据复制详解:类型、原理与适用场景
java·开发语言·数据库
2301_7717172115 小时前
解决mysql报错:1406, Data too long for column
android·数据库·mysql
axng pmje15 小时前
Java语法进阶
java·开发语言·jvm
rKWP8gKv715 小时前
Java微服务性能监控:Prometheus与Grafana集成方案
java·微服务·prometheus
老前端的功夫15 小时前
【Java从入门到入土】28:Stream API:告别for循环的新时代
java·开发语言·python
qq_4352879215 小时前
第9章 夸父逐日与后羿射日:死循环与进程终止?十个太阳同时值班的并行冲突
java·开发语言·git·死循环·进程终止·并行冲突·夸父逐日
小江的记录本15 小时前
【Kafka核心】架构模型:Producer、Broker、Consumer、Consumer Group、Topic、Partition、Replica
java·数据库·分布式·后端·搜索引擎·架构·kafka
dvjr cloi15 小时前
MySQL Workbench菜单汉化为中文
android·数据库·mysql
yaoxin52112316 小时前
397. Java 文件操作基础 - 创建常规文件与临时文件
java·开发语言·python
dFObBIMmai16 小时前
MySQL主从同步中大事务导致的延迟_如何拆分大事务优化同步
jvm·数据库·python