core--线程池

时间:2021-01-15 20:46:30

对于服务器-客户端这种架构的软件,通常客户端的数据来自于服务器,如何让一个服务器进程,来满足多个客户端程序的数据请求?一种简单的方法就是,每当一个客户请求来领,服务器就为该客户端创建一个线程。当有100个客户端请求,服务器就应该有100个数据结构分别管理每一个线程。通常服务器还要为每个客户端如何分配,哪个客户端发多少数据进行动态的调整。这是一个非常复杂的工作。好的是,windows为我们提供了一个这种问题的解决方案--线程池

线程池编程,只需要关心任务本身,而不需要去创建,管理,销毁线程。为了便于理解,我们的可以将我们编程的线程代码当做一个任务,交给线程机器人,然后让线程去执行。线程池就是一个超级机器人,专门用来管理每一个线程。

线程池有一下4个应用场景:

1.异步方式的函数调用

2.定时函数调用

3.内核促发时函数调用

4.异步I/O请求完成时函数调用

使用通过4步来实现

1.根据所选择的应用场景实现一个函数调用原型

4种应用场景的函数模型分别为:

VOID CALLBACK WorkCallback

VOID CALLBACK TimeoutCallBack

VOID CALLBACK WaitCallBack

VOID CALLBACK OverlappedCompletionRoutine

2.创建一个工作项

4种应用场景的函数模型分别为:

PTP_WORK CreateThreadPoolWork(@WorkCallback,…)

PTP_TIMER CreateThreadPoolTimer(@TimeoutCallBack,….)

PTP_WAIT CreateThreadPoolWait(@WaitCallBack,…)

PTP_IO CreateThreadPoolTO(…,@OverlappedCompletionRoutine,…)

3.将工作项提交到线程池

4种应用场景的函数模型分别为:

SubmitThreadPoolWort(PTP_WORK,…)

SetThreadPoolTimer(PTP_TIMER,…)

SetThreadPoolWait(PTP_WAIT,…)

StartThreadPoolIO(PTP_IO,…)

4.关闭工作项

4种应用场景的函数模型分别为:

CloseThreadPoolWork(PTP_WORK)

CloseThreadPoolTimer(PTP_TIMER)

CloseThreadPoolWait(PTP_WAIT)

CloseThreadPoolIO(PTP_IO)