.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‌:更适合执行时间较短、数量较多的后台任务。

‌性能优势‌

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

相关推荐
j***8270几秒前
MySQL 启动失败 (code=exited, status=1FAILURE) 异常解决方案
数据库·mysql
r***869813 分钟前
【MySQL 的数据目录】
数据库·mysql·adb
8***J18221 分钟前
SQL进阶——JOIN操作详解
数据库·sql·oracle
旷野说26 分钟前
如何用 Redpanda + 本地事务,实现“发消息 + 写 DB” 的强一致性!
java·数据库·kafka
unclecss33 分钟前
从 0 到 1 落地 SSE:Spring Boot 3 实战 Server-Sent Events 推送全链路
java·spring boot·后端·http·sse
e***956435 分钟前
springboot-自定义注解
java·spring boot·spring
管理大亨36 分钟前
Canal:企业数据实时同步的利器
数据库·mysql
stormsha36 分钟前
Java 设计模式探秘饿汉式与懒汉式单例模式的深度解析
java·单例模式·设计模式·java-ee
稚辉君.MCA_P8_Java40 分钟前
DeepSeek Java 多线程打印的19种实现方法
java·linux·jvm·后端·架构
白露与泡影44 分钟前
spring Security 认证流程闭环与调用链路详解
java·后端·spring