线程池linux,主题:一个简单的linux线程池

本文介绍了线程池的概念,它能有效管理线程的创建和销毁,提高系统效率。文章详细讲解了Linux中使用的posix线程库的关键函数,如pthread_create、pthread_join等,并阐述了线程池的三个主要组成部分:线程创建、任务添加和任务执行。通过CTask和CThreadPool两个类的示例,展示了如何实现任务类和线程池类,包括任务的执行逻辑和线程同步机制。
摘要由CSDN通过智能技术生成

线程池

:简单地说,线程池

就是预先创建好一批线程,方便、快速地处理收到的业务。比起传统的到来一个任务,即时创建一个线程来处理,节省了线程的创建和回收的开销,响应更快,效率

更高。

在linux中,使用的是posix线程库,首先介绍几个常用的函数:

1 线程的创建和取消函数

pthread_create

创建

pthread_join

合并线程

pthread_cancel

取消线程

2 线程同步函数

pthread_mutex_lock

pthread_mutex_unlock

pthread_cond_signal

pthread_cond_wait

关于函数的详细说明,参考man手册

线程池的实现:

线程池的实现主要分为三部分,线程的创建、添加任务到线程池中、工作线程从任务队列中取出任务进行处理。

主要有两个类来实现,CTask,CThreadPool

/**

执行任务的类,设置任务数据并执行

**/

class CTask

{

protected:

string m_strTaskName; //任务的名称

void* m_ptrData; //要执行的任务的具体数据

public:

CTask(){}

CTask(string taskName)

{

this->m_strTaskName = taskName;

m_ptrData = NULL;

}

virtual int Run()= 0;

void SetData(void* data); //设置任务数据

};

任务类是个虚类,所有的任务要从CTask类中继承

,实现run接口,run接口中需要实现的就是具体解析任务的逻辑。m_ptrData是指向任务数据的指针,可以是简单数据类型,也可以是自定义的复杂

数据类型。

线程池类

/**

线程池

**/

class CThreadPool

{

private:

vector m_vecTaskList; //任务列表

int m_iThreadNum; //线程池中启动的线程数

static vector m_vecIdleThread; //当前空闲的线程集合

static vector m_vecBusyThread; //当前正在执行的线程集合

static pthread_mutex_t m_pthreadMutex; //线程同步锁

static pthread_cond_t m_pthreadCond; //线程同步的条件变量

protected:

static void* ThreadFunc(void * threadData); //新线程的线程函数

static int MoveToIdle(pthread_t tid); //线程执行结束后,把自己放入到空闲线程中

static int MoveToBusy(pthread_t tid); //移入到忙碌线程中去

int Create(); //创建所有的线程

public:

CThreadPool(int threadNum);

int AddTask(CTask *task); //把任务添加到线程池中

int StopAll(

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值