ATL 线程池的使用
一.自定义一个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
- Initialize初始化线程数量,并初始化Worker
- QueueRequest则调用Worker的Execute方法
- 等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 线程池的使用相关推荐
- Windows下一个比较完美的线程池实现
1. 前言 线程池不是一个新鲜的东西,网上能找到很多原理.实现,甚至很多库都提供了实现,比如微软的 ATL::CThreadPool, Vista后提供的CreateThreadpoolWork, ...
- java 手编线程池_死磕 java线程系列之自己动手写一个线程池
欢迎关注我的公众号"彤哥读源码",查看更多源码系列文章, 与彤哥一起畅游源码的海洋. (手机横屏看源码更方便) 问题 (1)自己动手写一个线程池需要考虑哪些因素? (2)自己动手写 ...
- Python 多线程总结(2)— 线程锁、线程池、线程数量、互斥锁、死锁、线程同步
主要介绍使用 threading 模块创建线程的 3 种方式,分别为: 创建 Thread 实例函数 创建 Thread 实例可调用的类对象 使用 Thread 派生子类的方式 多线程是提高效率的一种 ...
- 详解 Tomcat 的连接数与线程池
原文出处:编程迷思 前言 在使用tomcat时,经常会遇到连接数.线程数之类的配置问题,要真正理解这些概念,必须先了解Tomcat的连接器(Connector). 在前面的文章 详解Tomcat配置文 ...
- Android线程池简单使用
线程池使用的好处: 1)对多个线程进行统一地管理,避免资源竞争中出现的问题. 2)对线程进行复用,线程在执行完任务后不会立刻销毁,而会等待另外的任务,这样就不会频繁地创建.销毁线程和调用GC. 使用T ...
- 四种Java线程池用法解析
四种Java线程池用法解析 本文为大家分析四种Java线程池用法,供大家参考,具体内容如下 http://www.jb51.net/article/81843.htm 1.new Thread的弊端 ...
- python基础-第九篇-9.3线程池
简单版 import queue import threadingclass ThreadPool(object):def __init__(self, max_num=20):self.queue ...
- mongodb线程池_常用高并发网络线程模型设计及MongoDB线程模型优化实践
服务端通常需要支持高并发业务访问,如何设计优秀的服务端网络IO工作线程/进程模型对业务的高并发访问需求起着至关重要的核心作用. 本文总结了了不同场景下的多种网络IO线程/进程模型,并给出了各种模型的优 ...
- 面试必问---Java线程池8大拒绝策略
前言 谈到java的线程池最熟悉的莫过于ExecutorService接口了,jdk1.5新增的java.util.concurrent包下的这个api,大大的简化了多线程代码的开发.而不论你用Fix ...
最新文章
- HDOJ 1214 圆桌会议
- 【控制】《最优控制理论与系统》-胡寿松老师-第2章-最优控制中的变分法
- 设计模式C++实现(5)——原型模式、模板方法模式
- POJ3468 A Simple Problem with Integers【线段树 成段更新+求和 lazy标志】
- 斐波那契数列的两种实现呢
- linux下安装mysql5.7.19,Linux下MySQL5.1升级到高版本MySQL5.7.19详解 | zifangsky的个人博客...
- Linux操作系统:文件和目录命令
- Chrome 成为互联网看门人?!
- C#将十进制转二进制
- GP数据库(Greenplum)单机版安装
- 部署Extmail邮件服务器教程——适用于小白
- 局域网内服务器做网站,如何在局域网内建立一个内网网站
- 1e9个兵临城下 容斥
- CIE1931-XYZ转CCT和Duv
- 笔记本电脑没有声音如何解决
- 深度学习相关概念:权重初始化
- 几种for循环用法详解。
- 禁止在input中输入中文
- judgement_mna_2016
- mysql自学英语差怎么_英语太差怎么办?
热门文章
- 关于神经网络权重初始值的设置的研究
- matlab guide 将matlab处理过的图片保存
- mix2s android p功能,已升安卓P!网友:MIX2S才是亲儿子
- java调用 restapi 乱码_Java HttpURLConnection模拟请求Rest接口解决中文乱码问题
- 速达财务3000服务器账套维护显示,速达3000财务软件使用常见问题
- arthas 查看哪个方法调用最耗时_阿里巴巴问题排查神器Arthas使用实践
- linux基础磁盘管理,Linux基础入门-文件系统操作与磁盘管理
- 如何安装mysql5.7.2_CentOS 7.2 安装MySQL 5.7
- C++ 求一元二次方程的根
- 音乐美术计算机在中考,2022年音乐、美术进中考?教育部最新回应...