一.自定义一个Worker

class CMyWorker{public:typedef MyRequestType RequestType;BOOL Initialize(void* pvWorkerParam);void Execute(MyRequestType request, void* pvWorkerParam, OVERLAPPED* pOverlapped);void Terminate(void* pvWorkerParam);};

必须实现以上接口

具体参考如下:

http://msdn.microsoft.com/zh-cn/library/ytkt93h8.aspx

Demo:

LONG g_lCurrId = -1;class CMyWorker
{
public:typedef DWORD_PTR RequestType;CMyWorker() : m_dwExecs( 0 ){m_lId = InterlockedIncrement( &g_lCurrId );}virtual BOOL Initialize(void *pvParam){printf("[%d]: CMyWorker.Initialize(%d)\n", (DWORD_PTR)::GetCurrentThreadId(), (DWORD_PTR)pvParam );return TRUE;}virtual void Terminate(void* /*pvParam*/){printf( "CMyWorker #%d exec'd %d times.\n", m_lId, m_dwExecs );}void Execute(RequestType dw, void *pvParam, OVERLAPPED* pOverlapped) throw(){ATLASSERT(pvParam != NULL);printf("[%d] CMyWorker::Execute(dw=%d, pvParam=%d, pOverlapped=%d\n", ::GetCurrentThreadId(), dw, (DWORD_PTR)pvParam, (DWORD_PTR)pOverlapped);CTaskBase* pTask = (CTaskBase*)(DWORD_PTR)dw;pTask->DoTask(pvParam, pOverlapped);m_dwExecs++;}virtual BOOL GetWorkerData(DWORD /*dwParam*/, void ** /*ppvData*/){return FALSE;}protected:DWORD    m_dwExecs;LONG    m_lId;
}; // CMyWorker

二.线程池(CThreadPool)

#define THREADPOOL_SIZE    5///
int main(int /*argc*/, char* /*argv[]*/)
{CThreadPool<CMyWorker> pool;CTaskArray    tasks;HRESULT hr = pool.Initialize((void*)321, THREADPOOL_SIZE);if( SUCCEEDED( hr ) ) {int i = -1;CTaskBase* pTask = NULL;if ( CreateTasks(tasks, 100) ) {for ( i = 0; i < tasks.GetSize(); i++ ) {pTask = tasks[ i ];ATLASSERT( NULL != pTask );pool.QueueRequest( (CMyWorker::RequestType) pTask );}}// Allow a little time for all the tasks to completeSleep(1000);// Clean up the tasks and shutdown the thread poolfor ( i = 0; i < tasks.GetSize(); i++ ) {pTask = tasks[ i ];ATLASSERT( NULL != pTask );delete pTask;}// Shutdown the thread poolpool.Shutdown();}elseprintf("Failed to init thread pool!");printf("\n");return 0;
}

参考:http://msdn.microsoft.com/zh-cn/library/dta23y51.aspx

  1. Initialize初始化线程数量,并初始化Worker
  2. QueueRequest则调用Worker的Execute方法
  3. 等Worker全部执行完毕以后才调用Terminate方法

三.IThreadPoolConfig

定义了一个基础的接口

// Used to configure the worker thread pool. This can be used by any
// client of the CThreadPool class.
__interface __declspec(uuid("B1F64757-6E88-4fa2-8886-7848B0D7E660"))IThreadPoolConfig : public IUnknown
{STDMETHOD(SetSize)(_In_ int nNumThreads);STDMETHOD(GetSize)(_Out_ int *pnNumThreads);STDMETHOD(SetTimeout)(_In_ DWORD dwMaxWait);STDMETHOD(GetTimeout)(_Out_ DWORD *pdwMaxWait);
};

四.ThreadTraits

分两种CRTThreadTraits和Win32ThreadTraits,分别调用_beginthreadex和CreateThread方法

五.WaitTraits

只实现了Win32WaitTraits了,即调用了WaitForSingleObject

转载于:https://www.cnblogs.com/Clingingboy/archive/2011/07/16/2108391.html

ATL 线程池的使用相关推荐

  1. Windows下一个比较完美的线程池实现

    1.  前言 线程池不是一个新鲜的东西,网上能找到很多原理.实现,甚至很多库都提供了实现,比如微软的 ATL::CThreadPool, Vista后提供的CreateThreadpoolWork, ...

  2. java 手编线程池_死磕 java线程系列之自己动手写一个线程池

    欢迎关注我的公众号"彤哥读源码",查看更多源码系列文章, 与彤哥一起畅游源码的海洋. (手机横屏看源码更方便) 问题 (1)自己动手写一个线程池需要考虑哪些因素? (2)自己动手写 ...

  3. Python 多线程总结(2)— 线程锁、线程池、线程数量、互斥锁、死锁、线程同步

    主要介绍使用 threading 模块创建线程的 3 种方式,分别为: 创建 Thread 实例函数 创建 Thread 实例可调用的类对象 使用 Thread 派生子类的方式 多线程是提高效率的一种 ...

  4. 详解 Tomcat 的连接数与线程池

    原文出处:编程迷思 前言 在使用tomcat时,经常会遇到连接数.线程数之类的配置问题,要真正理解这些概念,必须先了解Tomcat的连接器(Connector). 在前面的文章 详解Tomcat配置文 ...

  5. Android线程池简单使用

    线程池使用的好处: 1)对多个线程进行统一地管理,避免资源竞争中出现的问题. 2)对线程进行复用,线程在执行完任务后不会立刻销毁,而会等待另外的任务,这样就不会频繁地创建.销毁线程和调用GC. 使用T ...

  6. 四种Java线程池用法解析

    四种Java线程池用法解析 本文为大家分析四种Java线程池用法,供大家参考,具体内容如下 http://www.jb51.net/article/81843.htm 1.new Thread的弊端 ...

  7. python基础-第九篇-9.3线程池

    简单版 import queue import threadingclass ThreadPool(object):def __init__(self, max_num=20):self.queue ...

  8. mongodb线程池_常用高并发网络线程模型设计及MongoDB线程模型优化实践

    服务端通常需要支持高并发业务访问,如何设计优秀的服务端网络IO工作线程/进程模型对业务的高并发访问需求起着至关重要的核心作用. 本文总结了了不同场景下的多种网络IO线程/进程模型,并给出了各种模型的优 ...

  9. 面试必问---Java线程池8大拒绝策略

    前言 谈到java的线程池最熟悉的莫过于ExecutorService接口了,jdk1.5新增的java.util.concurrent包下的这个api,大大的简化了多线程代码的开发.而不论你用Fix ...

最新文章

  1. HDOJ 1214 圆桌会议
  2. 【控制】《最优控制理论与系统》-胡寿松老师-第2章-最优控制中的变分法
  3. 设计模式C++实现(5)——原型模式、模板方法模式
  4. POJ3468 A Simple Problem with Integers【线段树 成段更新+求和 lazy标志】
  5. 斐波那契数列的两种实现呢
  6. linux下安装mysql5.7.19,Linux下MySQL5.1升级到高版本MySQL5.7.19详解 | zifangsky的个人博客...
  7. Linux操作系统:文件和目录命令
  8. Chrome 成为互联网看门人?!
  9. C#将十进制转二进制
  10. GP数据库(Greenplum)单机版安装
  11. 部署Extmail邮件服务器教程——适用于小白
  12. 局域网内服务器做网站,如何在局域网内建立一个内网网站
  13. 1e9个兵临城下 容斥
  14. CIE1931-XYZ转CCT和Duv
  15. 笔记本电脑没有声音如何解决
  16. 深度学习相关概念:权重初始化
  17. 几种for循环用法详解。
  18. 禁止在input中输入中文
  19. judgement_mna_2016
  20. mysql自学英语差怎么_英语太差怎么办?

热门文章

  1. 关于神经网络权重初始值的设置的研究
  2. matlab guide 将matlab处理过的图片保存
  3. mix2s android p功能,已升安卓P!网友:MIX2S才是亲儿子
  4. java调用 restapi 乱码_Java HttpURLConnection模拟请求Rest接口解决中文乱码问题
  5. 速达财务3000服务器账套维护显示,速达3000财务软件使用常见问题
  6. arthas 查看哪个方法调用最耗时_阿里巴巴问题排查神器Arthas使用实践
  7. linux基础磁盘管理,Linux基础入门-文件系统操作与磁盘管理
  8. 如何安装mysql5.7.2_CentOS 7.2 安装MySQL 5.7
  9. C++ 求一元二次方程的根
  10. 音乐美术计算机在中考,2022年音乐、美术进中考?教育部最新回应...