QThead实现模拟VC工作线程函数

原创 2015年03月15日 16:39:41
// 刚了解QT,感觉QT的线程类QThread使用很不方便,多数情况下只是用到线程函数而已,而QT非得由QThread派生一个类来处理多线程,使用极为不方便,因此自己封装了一个类
// 用来模拟VC中的工作线程函数,其中一些Windows线程特性QT好象不支持(线程挂起,唤醒,运行于某个核等等,因本人对QT也不太了解,不知道是不支持还是自己没找到方法),
// 所以有几个函数暂未实现,如哪位朋友能实现,请告之,在此谢过。
// 头文件
#ifndef QTHREADBASE_H
#define QTHREADBASE_H
 
#include <iostream>
#include <stdlib.h>
#include <qmutex.h>
#include <Qthread.h>
#include <list>
 
#ifdef _MAC
#define CALLBACK    PASCAL
#define WINAPI      CDECL
#define WINAPIV     CDECL
#define APIENTRY    WINAPI
#define APIPRIVATE  CDECL
#ifdef _68K_
#define PASCAL      __pascal
#else
#define PASCAL
#endif
#elif (_MSC_VER >= 800) || defined(_STDCALL_SUPPORTED)
#define CALLBACK    __stdcall
#define WINAPI      __stdcall
#define WINAPIV     __cdecl
#define APIENTRY    WINAPI
#define APIPRIVATE  __stdcall
#define PASCAL      __stdcall
#else
#define CALLBACK
#define WINAPI
#define WINAPIV
#define APIENTRY    WINAPI
#define APIPRIVATE
#define PASCAL      pascal
#endif
 
class CThread: public QThread
{
public:
    CThread();
    virtual ~CThread();
public:
    // 设置等待超时
    void SetTimOut(unsigned long dwTimeOut = ULONG_MAX);
    // 获取等待超时
    unsigned long  GetTimeOut();
    // 允许线程强制退出
    void EnableTerminateThread(bool bEnable = false);
    bool IsEnableTerminateThread();
    // 线程退出标志
    bool IsQuit();
    // 设置线程退出标示
    void SetQuit(bool bQuit);
    // 线程延迟
    void ThreadSleep(unsigned long dwTime);
    // 启动线程
    bool StartThread(void (WINAPI *ThreadFun)(void* pParam) ,Priority nPriority = NormalPriority,void* ThreadParam = NULL);
    // 设置线程权限
    bool SetThreadPriority(Priority priority);
    // 恢复线程
    unsigned long ResumeThread();
    // 挂起线程
    unsigned long SuspendThread();
    // 设置线程与CPU某个核运行
    unsigned long SetThreadAffinityMask(unsigned long dwThreadAffinityMask);
    // 等待线程退出
    bool WaitQuit(unsigned long dwMilliseconds);
    // 强制杀掉线程
    bool TerminateThread();
public:
    void SetCustomData(void *lpData);
    void *GetCustomData();
private:
    void run();
private:
    void (WINAPI *FUN_ThreadFun)(void* pParam);
    void*    m_lpThreadParam;
 
    unsigned long m_dwTimeOut;
    // 允许强行杀线程
    bool m_bEnableForceKill;
    bool m_bAllowExit;
    // 自定用户参数
    void *m_lpCustomData;
};
 
#endif // QTHREADBASE_H

// cpp文件
#include "Thread.h"
 
CThread::CThread()
{
    m_dwTimeOut = ULONG_MAX;
    m_bEnableForceKill = false;
    SetQuit(false);
 
    m_lpCustomData = NULL;
}
CThread::~CThread()
{
    SetQuit(true);
    if(!IsEnableTerminateThread())
    {
        if(!WaitQuit(m_dwTimeOut))
        {
            TerminateThread();
        }
    }
    else
    {
        TerminateThread();
    }
}
void CThread::SetCustomData(void *lpData)
{
    m_lpCustomData = lpData;
}
 
void *CThread::GetCustomData()
{
    return m_lpCustomData;
}
 
void CThread::run()
{
    if(FUN_ThreadFun)
    {
        FUN_ThreadFun(m_lpThreadParam);
    }
}
 
bool CThread::WaitQuit(unsigned long dwMilliseconds)
{
    return wait(dwMilliseconds);
}
void CThread::EnableTerminateThread(bool bEnable)
{
    m_bEnableForceKill = bEnable;
}
bool CThread::IsEnableTerminateThread()
{
    return m_bEnableForceKill;
}
 
void CThread::SetTimOut(unsigned long dwTimeOut)
{
    m_dwTimeOut = dwTimeOut;
}
unsigned long CThread::GetTimeOut()
{
    return m_dwTimeOut;
}
bool CThread::IsQuit()
{
    return m_bAllowExit;
}
void CThread::SetQuit(bool bQuit)
{
    m_bAllowExit = bQuit;
}
void CThread::ThreadSleep(unsigned long dwTime)
{
    if( dwTime > 10)
    {
        unsigned int dwCount = 0;
        while(!IsQuit())
        {
            QThread::msleep(10);
 
            if(++dwCount > (unsigned int)(dwTime / 10))
            {
                break;
            }
        }
    }
    else
    {
        QThread::msleep(dwTime);
    }
}
 
// If the function succeeds, the return value is nonzero.
unsigned long CThread::SetThreadAffinityMask(unsigned long dwThreadAffinityMask)
{// 暂未实现
    return 0;
}
bool CThread::StartThread(void (WINAPI *ThreadFun)(void* pParam),Priority nPriority,void* ThreadParam)
{
    FUN_ThreadFun = ThreadFun;
    m_lpThreadParam = ThreadParam;
 
    start(nPriority);
    return true;
}
//设置优先级为高于正常
bool CThread::SetThreadPriority(Priority priority)
{
    setPriority(priority);
    return false;
}
unsigned long CThread::ResumeThread()
{// 暂未实现
    return 0xFFFFFFFF;
}
unsigned long CThread::SuspendThread()
{// 暂未实现
    return 0xFFFFFFFF;
}
 
// 强制杀掉线程
bool CThread::TerminateThread()
{
    terminate();
 
    return true;
}

//调用:
static void WINAPI Thread_Fun(void* wParam);
void CTest::Start()
{
  CThread *pThead = new CThread ;
   pThead ->SetCustomData(this);
   pThead ->SetTimOut(2000);
   pThead ->StartThread(Thread_Fun,CThread::NormalPriority,pThead );
}
 
void WINAPI CTest::Thread_Fun(void* wParam)
{
  CThread *pThread = (CThread*)wParam;
  if(pThread)
  {
    CTest*pFrame = (CTest*)pThread->GetCustomData();
    if(pFrame)
    {
      while(!pThread->IsQuit())
      {
        // 处理指令函数 
        pThread->ThreadSleep(1);
      }
    }
  }
}

VC 线程通信的3种方法

1.使用全局变量    实现线程间通信的方法有很多,常用的主要是通过全局变量、自定义消息和事件对象等来实现的。其中又以对全局变量的使用最为简洁。该方法将全局变量作为线程监视的对象,并通过在主线程对此...
  • slj_win
  • slj_win
  • 2014年03月18日 09:37
  • 799

VC多线程编程之线程创建与示例

一、问题的提出 编写一个耗时的单线程程序:   新建一个基于对话框的应用程序SingleThread,在主对话框IDD_SINGLETHREAD_DIALOG添加一个按钮,ID为IDC_SLEEP...
  • jiaxiaokai
  • jiaxiaokai
  • 2017年01月12日 16:51
  • 755

vc++多线程编程

1.CWinApp是一个i额用户界面线程对象,派生自CWinThread,处理用户产生的事件和消息。 MFC 2.AfxBeginThread函数创建和初始化CWinThread对象,启动并返回地址...
  • h1023417614
  • h1023417614
  • 2015年03月02日 19:36
  • 1838

VC++工作者线程关闭的问题

在使用MFC做一个activex小控件时引入了多线程,我使用的工作者线程,主体功能没有问题,但是退出IE浏览器里总是发生崩溃的问题,仔细跟了一下,发现是内存有泄露,其他的好都好说,new完后,记得de...
  • atrueman123
  • atrueman123
  • 2015年04月12日 12:55
  • 1015

UI线程和工作者线程

线程分为UI线程和工作者线程,UI线程有窗口,窗口自建了消息队列,这个UI线程维护“消息队列”,“消息队列”是界面线程和工 作者线程的最大区别。所以有用户界面的一般称为UI线程,没有界面的称...
  • libaineu2004
  • libaineu2004
  • 2014年10月23日 15:36
  • 1667

Qt QThread 这是我 见过解析最全面的一片文章

回顾Qt之线程(QThread),里面讲解了如何使用线程,但还有很多人留言没有看明白,那么今天我们来一起瞅瞅关于QThread管理线程的那些事儿。。。 一、线程管理 1、线程启动 ...
  • xiaobai_2511
  • xiaobai_2511
  • 2016年04月29日 15:23
  • 2264

VC++ 创建线程的三种方式以及如何进行选择

1. HANDLE WINAPI CreateThread( __in          LPSECURITY_ATTRIBUTES lpThreadAttributes, __in      ...
  • educast
  • educast
  • 2013年01月09日 16:31
  • 1569

VC线程安全退出的方法

1. 如果创建的线程属于阻塞类型的,比如线程函数中有套接字recv、sendto类似的操作,可能会死等着接收数据,这时想要退出该线程,只能用: BOOL TerminateThread( HANDL...
  • kelery
  • kelery
  • 2016年05月12日 10:05
  • 1176

VC退出线程的方法

标题很简单,但是要讨论的地方不少; 多线程管理,在程序开发中非常重要,虽然...
  • chinabinlang
  • chinabinlang
  • 2014年04月23日 10:24
  • 21673

VC启动一个新线程的三种方法

主要用AfxBeginThread()函数来 UINT  myproc(LPVOID  lParam) { CITTDlg *pWnd = (CITTDlg *)lParam; pWnd->KMe...
  • u014568921
  • u014568921
  • 2015年03月14日 19:53
  • 8242
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:QThead实现模拟VC工作线程函数
举报原因:
原因补充:

(最多只允许输入30个字)