C# 浅谈异步编程 Thread、ThreadPool

异步编程

从 .NET Framework 4 开始,使用多线程的推荐方法是使用任务并行库 (TPL) 和并行 LINQ (PLINQ)。

任务并行库(TPL)说的是 System.Threading 和 System.Threading.Tasks 空间中的一组公共类型和 API。较为常见的就是Thread、ThreadPool、Task等

LINQ (PLINQ) 是语言集成查询 (LINQ) 模式的并行实现,可以理解为对LINQ的一些扩充方法,类似于"IEnumerable .AsParallel()"方法。

1、Thread和ThreadPoool

1.1、线程Thread

创建和控制线程,设置其优先级并获取其状态。

使用举例:

cs 复制代码
public static void ThreadProc()
{
    for (int i = 0; i < 10; i++)
    {
        Console.WriteLine("ThreadProc: {0}", i);
        Thread.Sleep(1);
    }
}

public static void MainThread()
{
    Console.WriteLine("Main thread Start.");
    Console.WriteLine("Creat a second thread: ThreadProc.");
    Thread t = new Thread(new ThreadStart(ThreadProc));
    Console.WriteLine("ThreadProc start.");
    t.Start();

    for (int i = 0; i < 4; i++)
    {
        Console.WriteLine("Main thread: Do some work.");
        Thread.Sleep(1);
    }

    Console.WriteLine("Main thread: Call Join(), to wait until ThreadProc ends.");
    t.Join();
    Console.WriteLine("Main thread: ThreadProc.Join has returned.  Press Enter to end program.");
    Console.ReadLine();
}

ThreadStart为系统自带无参委托类型。

Thread的构造函数有如下几种:

cs 复制代码
public Thread(ThreadStart start)...    
public Thread(ParameterizedThreadStart start)...
public Thread(ThreadStart start, int maxStackSize)...
public Thread(ParameterizedThreadStart start, int maxStackSize)...

1.2、线程池ThreadPoool

先说说进程,进程是一种正在执行的程序,操作系统使用进程来分隔正在执行的应用程序。

可以把线程池比喻成公路,一个进程只有一条公路,一条公路(线程池)上可以有多个车道。即是说一个进程只能有一个线程池,而线程池中可以有多个线程,而具体可以有多少线程呢,是受到计算机内存等限制的。

C#中可以使用 ThreadPool.GetMaxThreads 和 ThreadPool.SetMaxThreads 方法来控制最大线程数。
使用示例:

cs 复制代码
public static void ThreadProc(object stateInfo)
{
    for (int i = 0; i < 5; i++)
    {
        Console.WriteLine("ThreadProc: {0},stateInfo: {1}", i, stateInfo);
        Thread.Sleep(1);
    }
}
public static void MainThreadPool()
{
    ThreadPool.QueueUserWorkItem(ThreadProc, "state");
    Console.WriteLine("Main thread does some work, then sleeps.");
    Thread.Sleep(1000);

    Console.WriteLine("Main thread exits.");
}

输出:

cs 复制代码
Main thread does some work, then sleeps.
ThreadProc: 0,stateInfo: state
ThreadProc: 1,stateInfo: state
ThreadProc: 2,stateInfo: state
ThreadProc: 3,stateInfo: state
ThreadProc: 4,stateInfo: state
Main thread exits.

ThreadPool为静态类,只能操作当前进程的线程池。

常用方法除了GetMaxThreads() 和 SetMaxThreads()外,还有上面使用示例中出现的:

QueueUserWorkItem(WaitCallback callBack, object state)

QueueUserWorkItem(WaitCallback callBack)

即将方法排入队列以便执行。 此方法在有线程池线程变得可用时执行。

参数WaitCallBack是一个内置委托(如下👇),需要传递参数时使用第一种方法。

cs 复制代码
delegate void WaitCallback(object? state);
相关推荐
float_六七1 分钟前
C/C++中头文件time
c语言·开发语言·c++
ByteBlossom66615 分钟前
Java语言的多线程编程
开发语言·后端·golang
JoneMaster22 分钟前
[读书日志]从零开始学习Chisel 第八篇:Scala的集合(敏捷硬件开发语言Chisel与数字系统设计)
开发语言·学习·scala
编程小筑39 分钟前
C语言的循环实现
开发语言·后端·golang
2013crazy43 分钟前
Python 基于 opencv 的人脸识别监控打卡系统(源码+部署)
开发语言·python·opencv·python 人脸识别·python 人脸识别打卡
清醒的兰1 小时前
Qt 样式表
开发语言·qt
旷野..1 小时前
Java协程的引入会导致GC Root枚举复杂度大大增加,JVM是如何解决的呢?
java·开发语言·jvm
xiaowu0801 小时前
学习记录:C++ 中 const 引用的使用及其好处
开发语言·c++·算法
A_Tai23333332 小时前
Java多线程
java·开发语言
独自破碎E2 小时前
百济神州后端开发工程师 - 部分笔试题 - 解析
java·开发语言