一个Windows C++的线程类实现
Thread.h
- #ifndef __THREAD_H__
- #define __THREAD_H__
- #include <string>
- #include <windows.h>
- #include <process.h>
- class Runnable
- {
- public:
- virtual ~Runnable() {};
- virtual void Run() = 0;
- };
- class CThread : public Runnable
- {
- private:
- explicit CThread(const CThread & rhs);
- public:
- CThread();
- CThread(Runnable * pRunnable);
- CThread(const char * ThreadName, Runnable * pRunnable = NULL);
- CThread(std::string ThreadName, Runnable * pRunnable = NULL);
- ~CThread(void);
- /**
- 开始运行线程
- @arg bSuspend 开始运行时是否挂起
- **/
- bool Start(bool bSuspend = false);
- /**
- 运行的线程函数,可以使用派生类重写此函数
- **/
- virtual void Run();
- /**
- 当前执行此函数线程等待线程结束
- @arg timeout 等待超时时间,如果为负数,等待无限时长
- **/
- void Join(int timeout = -1);
- /**
- 恢复挂起的线程
- **/
- void Resume();
- /**
- 挂起线程
- **/
- void Suspend();
- /**
- 终止线程的执行
- **/
- bool Terminate(unsigned long ExitCode);
- unsigned int GetThreadID();
- std::string GetThreadName();
- void SetThreadName(std::string ThreadName);
- void SetThreadName(const char * ThreadName);
- private:
- static unsigned int WINAPI StaticThreadFunc(void * arg);
- private:
- HANDLE m_handle;
- Runnable * const m_pRunnable;
- unsigned int m_ThreadID;
- std::string m_ThreadName;
- volatile bool m_bRun;
- };
- #endif
Thread.cpp
- #include "Thread.h"
- CThread::CThread(void) :
- m_pRunnable(NULL),
- m_bRun(false)
- {
- }
- CThread::~CThread(void)
- {
- }
- CThread::CThread(Runnable * pRunnable) :
- m_ThreadName(""),
- m_pRunnable(pRunnable),
- m_bRun(false)
- {
- }
- CThread::CThread(const char * ThreadName, Runnable * pRunnable) :
- m_ThreadName(ThreadName),
- m_pRunnable(pRunnable),
- m_bRun(false)
- {
- }
- CThread::CThread(std::string ThreadName, Runnable * pRunnable) :
- m_ThreadName(ThreadName),
- m_pRunnable(pRunnable),
- m_bRun(false)
- {
- }
- bool CThread::Start(bool bSuspend)
- {
- if(m_bRun)
- {
- return true;
- }
- if(bSuspend)
- {
- m_handle = (HANDLE)_beginthreadex(NULL, 0, StaticThreadFunc, this, CREATE_SUSPENDED, &m_ThreadID);
- }
- else
- {
- m_handle = (HANDLE)_beginthreadex(NULL, 0, StaticThreadFunc, this, 0, &m_ThreadID);
- }
- m_bRun = (NULL != m_handle);
- return m_bRun;
- }
- void CThread::Run()
- {
- if(!m_bRun)
- {
- return;
- }
- if(NULL != m_pRunnable)
- {
- m_pRunnable->Run();
- }
- m_bRun = false;
- }
- void CThread::Join(int timeout)
- {
- if(NULL == m_handle || !m_bRun)
- {
- return;
- }
- if(timeout <= 0)
- {
- timeout = INFINITE;
- }
- ::WaitForSingleObject(m_handle, timeout);
- }
- void CThread::Resume()
- {
- if(NULL == m_handle || !m_bRun)
- {
- return;
- }
- ::ResumeThread(m_handle);
- }
- void CThread::Suspend()
- {
- if(NULL == m_handle || !m_bRun)
- {
- return;
- }
- ::SuspendThread(m_handle);
- }
- bool CThread::Terminate(unsigned long ExitCode)
- {
- if(NULL == m_handle || !m_bRun)
- {
- return true;
- }
- if(::TerminateThread(m_handle, ExitCode))
- {
- ::CloseHandle(m_handle);
- return true;
- }
- return false;
- }
- unsigned int CThread::GetThreadID()
- {
- return m_ThreadID;
- }
- std::string CThread::GetThreadName()
- {
- return m_ThreadName;
- }
- void CThread::SetThreadName(std::string ThreadName)
- {
- m_ThreadName = ThreadName;
- }
- void CThread::SetThreadName(const char * ThreadName)
- {
- if(NULL == ThreadName)
- {
- m_ThreadName = "";
- }
- else
- {
- m_ThreadName = ThreadName;
- }
- }
- unsigned int CThread::StaticThreadFunc(void * arg)
- {
- CThread * pThread = (CThread *)arg;
- pThread->Run();
- return 0;
- }
用法:
#include "Thread.h"
#include "ThreadPoolExecutor.h"
class R : public Runnable
{
public:
~R()
{
printf("~R/n");
}
void Run()
{
printf("Hello World/n");
}
};
int _tmain(int argc, _TCHAR* argv[])
{
R r;
CThread * t = NULL;
t = new CThread(&r);
t->Start();
t->Join();
getchar();
}
from:http://blog.csdn.net/huyiyang2010/article/details/5801597
一个Windows C++的线程类实现的更多相关文章
- 一个Windows C++的线程类实现(封装API,形成一个类,但不完善。其实可以学习一下Delphi的TThread的写法)
Thread.h #ifndef __THREAD_H__ #define __THREAD_H__ #include <string> #include <windows.h& ...
- 一个Windows C++的线程池的实现
此线程池所依赖的线程类,请参看<一个Windows C++的线程类实现>: http://blog.csdn.net/huyiyang2010/archive/2010/08/10/580 ...
- Delphi中线程类TThread实现多线程编程2---事件、临界区、Synchronize、WaitFor……
接着上文介绍TThread. 现在开始说明 Synchronize和WaitFor 但是在介绍这两个函数之前,需要先介绍另外两个线程同步技术:事件和临界区 事件(Event) 事件(Event)与De ...
- Java带参数的线程类ParameterizedThread——即如何给Thread传递参数
在Java中似乎没有提供带运行参数的线程实现类,在第三方类库中也没有找到.网上有大量的文章在讨论这个问题,但都没有提供很好的代码封装解决方案,这令我很吃惊.如果读者知道有官方或者第三方的实现方式,欢迎 ...
- Delphi线程类 DIY(把类指针作为参数传进去,就可以执行类里面的方法啦)
Delphi 封装了一个很强大的线程类 TThread, 我们也自己动手制作一个简单的线程类 首先Type一个类 type TwwThread = class constructor Create; ...
- 转:一个跨WINDOWS LINUX平台的线程类
来源:http://blog.csdn.net/dengxu11/article/details/7232681 继Windows下实现一个CThread封装类之后,这里我再实现一个跨WINDOWS ...
- 一个Windows下线程池的实现(C++)
前言 本文配套代码:https://github.com/TTGuoying/ThreadPool 先看看几个概念: 线程:进程中负责执行的执行单元.一个进程中至少有一个线程. 多线程:一个进程中有多 ...
- C# 模拟一个处理消息队列的线程类 Message Queue
// 模拟一个处理消息队列的类 class MessageHandler { // 消息队列 private Queue<string> messageQue = new Queue< ...
- 从零开始构建一个Reactor模式的网络库(二)线程类Thread
线程类Thread是对POSIX线程的封装类,因为要构建的是一个Linux环境下的多线程网络库,对线程的封装是很必要的. 首先是CurrentThread命名空间,主要是获取以及缓存线程id: #if ...
随机推荐
- 点击显示子菜单,离开隐藏子菜单(onmouseout下包含a标签的js解决方法)
<div class="menu"> <a href="javascript:void(0);" id="a_all&quo ...
- getHibernateTemplate()和getSession()的区别
自动生成hibernate配置文件的时候,会在dao层用到getSession()方法来操作数据库记录,但是他还有个方法getHibernateTemplate(),这两个方法究竟有什么区别呢? 1. ...
- [C#]6.0新特性浅谈
原文:[C#]6.0新特性浅谈 C#6.0出来也有很长一段时间了,虽然新的特性和语法趋于稳定,但是对于大多数程序猿来说,想在工作中用上C#6.0估计还得等上不短的一段时间.所以现在再来聊一聊新版本带来 ...
- zookeeper 手动T掉已挂节点
zjtest7-redis:/root/zk# cat test_zk.pl use ZooKeeper; use AnyEvent; use AE; use Data::Dumper; use IO ...
- aix6.1 openssh安装
环境: IBM AIX6.1 1.下载(可以直接从附件中下载): openssl IBM官方网站下载:https://www14.software.ibm.com/webapp/iwm/web/reg ...
- fuel iso光盘刻录机usb Driver 烧录
ISO image to a DVD or burn the IMG file to a USB drive For a bare-metal installation ipmitool, HP iL ...
- Android不规则瀑布流照片墙的实现+LruCache算法
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvZnJhbmNpc3NoaQ==/font/5a6L5L2T/fontsize/400/fill/I0JBQk ...
- SVN—怎样安装SVNserver端软件
一.怎样安装1.4.5版本号的SVNserver端软件: a.下载1.4.5版本号的SVNserver端软件.下载地址:http://download.csdn.net/download ...
- 使用logstash收集日志的可靠性验证
实时计算里,需要对日志实时收集,logstash可以做到.目前的版本是1.4.2,官方文档在http://www.logstash.net/docs/1.4.2/,里面有详细的配置说明,使用也很简单. ...
- C#中的USB库 WinUSB
NET C#中的USB库WinUSB,的libusb - Win32和的libusb - 1.0.使用公共设备类,应用程序与所有未经修改的操作系统和驱动程序.大量的示例代码. http://sourc ...