Thread.h

  1. #ifndef __THREAD_H__
  2. #define __THREAD_H__
  3. #include <string>
  4. #include   <windows.h>
  5. #include   <process.h>
  6. class Runnable
  7. {
  8. public:
  9. virtual ~Runnable() {};
  10. virtual void Run() = 0;
  11. };
  12. class CThread : public Runnable
  13. {
  14. private:
  15. explicit CThread(const CThread & rhs);
  16. public:
  17. CThread();
  18. CThread(Runnable * pRunnable);
  19. CThread(const char * ThreadName, Runnable * pRunnable = NULL);
  20. CThread(std::string ThreadName, Runnable * pRunnable = NULL);
  21. ~CThread(void);
  22. /**
  23. 开始运行线程
  24. @arg bSuspend 开始运行时是否挂起
  25. **/
  26. bool Start(bool bSuspend = false);
  27. /**
  28. 运行的线程函数,可以使用派生类重写此函数
  29. **/
  30. virtual void Run();
  31. /**
  32. 当前执行此函数线程等待线程结束
  33. @arg timeout 等待超时时间,如果为负数,等待无限时长
  34. **/
  35. void Join(int timeout = -1);
  36. /**
  37. 恢复挂起的线程
  38. **/
  39. void Resume();
  40. /**
  41. 挂起线程
  42. **/
  43. void Suspend();
  44. /**
  45. 终止线程的执行
  46. **/
  47. bool Terminate(unsigned long ExitCode);
  48. unsigned int GetThreadID();
  49. std::string GetThreadName();
  50. void SetThreadName(std::string ThreadName);
  51. void SetThreadName(const char * ThreadName);
  52. private:
  53. static unsigned int WINAPI StaticThreadFunc(void * arg);
  54. private:
  55. HANDLE m_handle;
  56. Runnable * const m_pRunnable;
  57. unsigned int m_ThreadID;
  58. std::string m_ThreadName;
  59. volatile bool m_bRun;
  60. };
  61. #endif

Thread.cpp

  1. #include "Thread.h"
  2. CThread::CThread(void) :
  3. m_pRunnable(NULL),
  4. m_bRun(false)
  5. {
  6. }
  7. CThread::~CThread(void)
  8. {
  9. }
  10. CThread::CThread(Runnable * pRunnable) :
  11. m_ThreadName(""),
  12. m_pRunnable(pRunnable),
  13. m_bRun(false)
  14. {
  15. }
  16. CThread::CThread(const char * ThreadName, Runnable * pRunnable) :
  17. m_ThreadName(ThreadName),
  18. m_pRunnable(pRunnable),
  19. m_bRun(false)
  20. {
  21. }
  22. CThread::CThread(std::string ThreadName, Runnable * pRunnable) :
  23. m_ThreadName(ThreadName),
  24. m_pRunnable(pRunnable),
  25. m_bRun(false)
  26. {
  27. }
  28. bool CThread::Start(bool bSuspend)
  29. {
  30. if(m_bRun)
  31. {
  32. return true;
  33. }
  34. if(bSuspend)
  35. {
  36. m_handle = (HANDLE)_beginthreadex(NULL, 0, StaticThreadFunc, this, CREATE_SUSPENDED, &m_ThreadID);
  37. }
  38. else
  39. {
  40. m_handle = (HANDLE)_beginthreadex(NULL, 0, StaticThreadFunc, this, 0, &m_ThreadID);
  41. }
  42. m_bRun = (NULL != m_handle);
  43. return m_bRun;
  44. }
  45. void CThread::Run()
  46. {
  47. if(!m_bRun)
  48. {
  49. return;
  50. }
  51. if(NULL != m_pRunnable)
  52. {
  53. m_pRunnable->Run();
  54. }
  55. m_bRun = false;
  56. }
  57. void CThread::Join(int timeout)
  58. {
  59. if(NULL == m_handle || !m_bRun)
  60. {
  61. return;
  62. }
  63. if(timeout <= 0)
  64. {
  65. timeout = INFINITE;
  66. }
  67. ::WaitForSingleObject(m_handle, timeout);
  68. }
  69. void CThread::Resume()
  70. {
  71. if(NULL == m_handle || !m_bRun)
  72. {
  73. return;
  74. }
  75. ::ResumeThread(m_handle);
  76. }
  77. void CThread::Suspend()
  78. {
  79. if(NULL == m_handle || !m_bRun)
  80. {
  81. return;
  82. }
  83. ::SuspendThread(m_handle);
  84. }
  85. bool CThread::Terminate(unsigned long ExitCode)
  86. {
  87. if(NULL == m_handle || !m_bRun)
  88. {
  89. return true;
  90. }
  91. if(::TerminateThread(m_handle, ExitCode))
  92. {
  93. ::CloseHandle(m_handle);
  94. return true;
  95. }
  96. return false;
  97. }
  98. unsigned int CThread::GetThreadID()
  99. {
  100. return m_ThreadID;
  101. }
  102. std::string CThread::GetThreadName()
  103. {
  104. return m_ThreadName;
  105. }
  106. void CThread::SetThreadName(std::string ThreadName)
  107. {
  108. m_ThreadName = ThreadName;
  109. }
  110. void CThread::SetThreadName(const char * ThreadName)
  111. {
  112. if(NULL == ThreadName)
  113. {
  114. m_ThreadName = "";
  115. }
  116. else
  117. {
  118. m_ThreadName = ThreadName;
  119. }
  120. }
  121. unsigned int CThread::StaticThreadFunc(void * arg)
  122. {
  123. CThread * pThread = (CThread *)arg;
  124. pThread->Run();
  125. return 0;
  126. }

用法:

#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();

}

http://blog.csdn.net/huyiyang2010/article/details/5801597

一个Windows C++的线程类实现(封装API,形成一个类,但不完善。其实可以学习一下Delphi的TThread的写法)的更多相关文章

  1. 一个Windows C++的线程池的实现

    此线程池所依赖的线程类,请参看<一个Windows C++的线程类实现>: http://blog.csdn.net/huyiyang2010/archive/2010/08/10/580 ...

  2. php函数、类和对象以及类的封装、继承、类的静态方法、静态属性

    1.函数     php内置函数可以直接使用,如果没有安装php扩展即可     自定义函数 //函数function 函数名 function dump($var = null){ //支出默认参数 ...

  3. 编写Java程序,实现对兵营类的封装,将兵营类中的所有属性设置为私有访问权限,方法设置为公有访问权限

    返回本章节 返回作业目录 需求说明: 实现对兵营类的封装 将兵营类中的所有属性设置为私有访问权限. 将兵营类中所有属性的赋值方法设置为公有访问权限. 要求兵营名称的长度在4-8位之间. 要求兵营士兵的 ...

  4. 01 语言基础+高级:1-5 常用API第二部分_day01.【Object类、常用API: Date类、System类、StringBuilder类】

    day01[Object类.常用API] 主要内容 Object类 Date类 DateFormat类 Calendar类 System类 StringBuilder类 包装类 java.lang.O ...

  5. 一个Windows C++的线程类实现

    Thread.h [cpp] view plaincopy #ifndef __THREAD_H__ #define __THREAD_H__ #include <string> #inc ...

  6. C++中的类与封装

    1,类的组合: 1,类不是孤立存在的,类之间都会有一些关系,组合就是类的基本关系之一: 2,电脑一般而言是由 CPU.内存.主板.键盘和硬盘等部件组合而成: 3,学习电脑组装需要多少时间?学习电脑组装 ...

  7. 一个Windows下线程池的实现(C++)

    前言 本文配套代码:https://github.com/TTGuoying/ThreadPool 先看看几个概念: 线程:进程中负责执行的执行单元.一个进程中至少有一个线程. 多线程:一个进程中有多 ...

  8. C++线程类的封装

    简单的C++线程操作的封装,使用了智能指针管理对象的释放. 可运行对象基类 class SimpleRunable:public RefCountedBase { public: SimpleRuna ...

  9. windows核心编程 - 线程同步机制

    线程同步机制 常用的线程同步机制有很多种,主要分为用户模式和内核对象两类:其中 用户模式包括:原子操作.关键代码段 内核对象包括:时间内核对象(Event).等待定时器内核对象(WaitableTim ...

随机推荐

  1. java的对象锁和对象传递

    1.对象传递 在JAVA的參数传递中,有两种类型,第一种是基本类型传递,比如int,float,double等,这样的是值传递,第二种是对象传递,比方String或者自己定义的类,这样的是引用传递. ...

  2. 【Nutch2.2.1基础教程之6】Nutch2.2.1抓取流程 分类: H3_NUTCH 2014-08-15 21:39 2530人阅读 评论(1) 收藏

    一.抓取流程概述 1.nutch抓取流程 当使用crawl命令进行抓取任务时,其基本流程步骤如下: (1)InjectorJob 开始第一个迭代 (2)GeneratorJob (3)FetcherJ ...

  3. 【搜索引擎Jediael开发4】V0.01完整代码 分类: H_HISTORY 2014-05-21 21:35 470人阅读 评论(0) 收藏

    截止目前,已完成如下功能: 1.指定某个地址,使用HttpClient下载该网页至本地文件 2.使用HtmlParser解释第1步下载的网页,抽取其中包含的链接信息 3.下载第2步的所有链接指向的网页 ...

  4. Java 并发工具包 java.util.concurrent 大全

    1. java.util.concurrent - Java 并发工具包 Java 5 添加了一个新的包到 Java 平台,java.util.concurrent 包.这个包包含有一系列能够让 Ja ...

  5. MIPS Instruction Set

    https://www.mips.com/develop/training-courses/mips-basic-training-course/ The MIPS64 Instruction Set ...

  6. Windows Phone 8.1 FilePicker API

    在 Windows Phone 8.1 中,增加了 FilePicker 的方式与文件打交道,最大的亮点在于这种方式不仅可以浏览手机上的文件,还可以浏览符合协议的应用里的文件! 比如点击 OneDri ...

  7. RSA公钥、私钥、签名和验签

    1 RSA加密算法介绍 RSA又叫非对称加密算法,这类加密算法有一对秘钥,其中一个用来加密一个用来解密.这一对秘钥中你可以选择一个作为私钥(自己保存),另一个作为公钥(对外公开).用私钥加密的内容只能 ...

  8. 修改VNC的分辨率

    http://blog.csdn.net/jlds123/article/details/9064437 有时候用VNC View打开远程linux桌面时,桌面显示不出来,只有一个灰色背景加上一个命令 ...

  9. PatentTips - Fast awake from low power mode

    BACKGROUND Electronic devices, such as electronic book readers ("eBook reader devices"), c ...

  10. 简单实现的Servlet文件上传,并显示

    http://my.oschina.net/Barudisshu/blog/157481