首先当然是先定义头文件Thread.h咯,如下:
#ifndef _THREAD_H
#define _THREAD_H
#ifdef _WIN32
#include <windows.h>
#else
#include <pthread.h>
#endif
#ifdef _WIN32
typedef unsigned threadfunc_t;
typedef void* threadparam_t;
#define STDPREFIX __stdcall
#else
typedef void* threadfunc_t;
typedef void* threadparam_t;
#define STDPREFIX
#endif
//线程的基类
class Thread
{
public:
Thread(bool release=true);
virtual ~Thread();
static threadfunc_t STDPREFIX StartThread(threadparam_t);
virtual void Run()=0; //纯虚函数,由派生类实现
#ifdef _WIN32
HANDLE GetThread(){return m_thread;}
unsigned GetThreadId(){return m_dwThreadId;}
#else
pthread_t GetThread(){return m_thread;}
#endif
bool IsRunning();
void SetRunning(bool x);
bool IsReleased();
void SetRelease(bool x);
bool DeleteOnExit();
void SetDeleteOnExit(bool x=true);
bool IsDestructor();
protected:
#ifdef _WIN32
HANDLE m_thread;
unsigned m_dwThreadId;
#else
pthread_t m_thread;
#endif
private:
Thread(const Thread&){}
Thread& operator=(const Thread&){return *this;}
bool m_running;
bool m_release;
bool m_b_delete_on_exit;
bool m_b_destructor;
};
#endif
接着是实现文件Thread.cpp,由于代码比较简单,就不多解释了,直接看代码里的注释就行了:
#include <stdio.h>
#ifdef _WIN32
#include <process.h>
#else
#include <unistd.h>
#endif
#include "Thread.h"
Thread::Thread(bool release)
:m_thread(0),
m_running(true),
m_release(false),
m_b_delete_on_exit(false),
m_b_destructor(false)
{
#ifdef _WIN32
m_thread = (HANDLE)_beginthreadex(NULL, 0, &StartThread,
this, 0, &m_dwThreadId);
#else
pthread_attr_t attr;
pthread_attr_init(&attr);
pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_DETACHED);
if(pthread_create(&m_thread, &attr, StartThread, this) == 1)
{
perror("Thread:create failed");
SetRunning(false);
}
#endif
m_release = release;
}
Thread::~Thread()
{
m_b_destructor = true;
if(m_running)
{
SetRelease(true);
SetRunning(false);
#ifdef _WIN32
Sleep(1000);
#else
sleep(1);
#endif
}
#ifdef _WIN32
if(m_thread)
::CloseHandle(m_thread);
#endif
}
//线程函数
threadfunc_t STDPREFIX Thread::StartThread(threadparam_t zz)
{
Thread *p = (Thread*)zz;
while(p->m_running && !p->m_release)
{
#ifdef _WIN32
Sleep(1000);
#else
sleep(1);
#endif
}
if(p->m_running)
{
p->Run();
}
p->SetRunning(false); //Run()运行完了,或根本没运行
if(p->DeleteOnExit() && !p->IsDestructor())
{
delete p;
}
#ifdef _WIN32
_endthreadex(0);
#endif
return (threadfunc_t)NULL;
}
bool Thread::IsRunning()
{
return m_running;
}
void Thread::SetRunning(bool x)
{
m_running = x;
}
bool Thread::IsReleased()
{
return m_release;
}
void Thread::SetRelease(bool x)
{
m_release = x;
}
//退出时是否释放线程对象Thread*
bool Thread::DeleteOnExit()
{
return m_b_delete_on_exit;
}
void Thread::SetDeleteOnExit(bool x)
{
m_b_delete_on_exit = x;
}
//是否已经调用了析构函数
bool Thread::IsDestructor()
{
return m_b_destructor;
}
分享到:
相关推荐
asce1885-blogasce1885的博客
ASCE7-10-建筑物和其他结构最小设计荷载-中文版.pdf
PHASE II OF THE ASCE BENCHMARK STUDY ON SHM
此为ASCE的第三代基准模型代码,可供土木工程领域学者使用。
ASCE是土木工程学会的重要期刊。国外期刊投稿主要是latex,该期刊有Latex的投稿模板。
土木工程几个著名期刊ASCE和Science direct中输出格式
希望大家能用得着这个东西!检索时很有用啊
mfc工程,一个可以编辑,选择能实现众多功能的list控件示范工程,
ASCE全文数据库培训iGroup公司.ppt
ASCE-7-2005-美国荷载规范-(中文版)
eclipse 配置AmaterasUML时需要的3个jar 包,以及配置文档 http://blog.csdn.net/asce1885/article/details/40744163
ANSI ASCE CI 71-21 Identifying, Quantifying, and Proving Loss of Productivity.pdf
ASCE_7-10美国建筑荷载规范(中文版);.pdf
957/5000 结构安全和结构动力学有许多领域,通常需要计算随机变量函数的前几个统计矩。 通常的近似是泰勒展开法。 这种方法需要计算导数。 为了避免导数的计算,已经提出了概率矩的点估计。 然而,准确度非常低,...
(ASCE 7-10 “Minimum Design Loads for Buildings and Other Structures”)主要内容翻译与介绍 目录 0 规范内容简介1 1 总则7 1.1 适用范围7 1.2 定义和解释7 1.3 基本要求7 1.3.1 强度和刚度7 1.3.2 适用性8 ...
针对美国IASC-ASCE的结构健康监测科研组提出的基准结构进行结构自振频率识别研究.神经网络训练时使用的数据为有限元程序计算所得出,将有损伤结构在环境激励下某点的加速度响应,通过快速傅立叶变换得到的离散频率响应...
应用该方法对由国际结构控制协会与美国土木工程学会(IASC-ASCE)提出的健康监测Benchmark结构进行了分析。结果表明,两阶段损伤诊断方法能够;隹确地定出可能损伤单元的位置与损伤程度,识别结果与真实的损伤接近,...
集成的建模模板,基于代码的负载分配,高级分析选项,设计优化过程以及可定制的输出报告,均跨一个强大的平台进行协调,从而使SAP2000特别适用于专业人员。 SAP2000 v25新功能 1、用户界面 添加了树结构模型资源...
考虑3种对称损伤模式和1种非对称损伤模式,对由国际结构控制协会与美国土木工程学会(IASC-ASCE)提出的健康监测Benchmark模型结构第二阶段有斜撑的情况进行模拟分析。结果表明:该方法能够有效地识别出结构损伤单元...
asce-common 可以重用并轻松集成到任何项目中的android通用代码