亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C++ > 正文

c++線程池實現方法

2020-01-26 15:04:04
字體:
來源:轉載
供稿:網友

本文實例講述了c++線程池實現方法。分享給大家供大家參考。具體分析如下:

下面這個線程池是我在工作中用到過的,原理還是建立一個任務隊列,讓多個線程互斥的在隊列中取出任務,然后執行,顯然,隊列是要加鎖的

環境:ubuntu linux

文件名:locker.h

#ifndef LOCKER_H_ #define LOCKER_H_ #include "pthread.h" class locker { public:   locker();   virtual ~locker();   bool lock();   void unlock(); private:   pthread_mutex_t   m_mutex; }; #endif /* LOCKER_H_ */ 

文件名:locker.cpp

#include "locker.h" locker::locker() {   pthread_mutex_init(&m_mutex, 0); } locker::~locker() {   pthread_mutex_destroy(&m_mutex); } bool locker::lock() {   if(0 == pthread_mutex_lock(&m_mutex))     return true;   return false; } void locker::unlock() {   pthread_mutex_unlock(&m_mutex); }

文件名:task_list.h

#ifndef TASK_LIST_H_ #define TASK_LIST_H_ #include "list" #include "locker.h" #include "netinet/in.h" #include "semaphore.h" using namespace std; typedef void* (*THREAD_FUNC)(void*); // 線程池中運行的任務,對于下行任務,sin中包含目的地址信息 // parm0指向發出數據的對象,parm1指向數據,parm2為數據的長度 typedef struct {   THREAD_FUNC func;   void* parm0;   void* parm1;   void* parm2; } task_info; typedef list<task_info*> TASK_LIST; typedef list<task_info*>::iterator PTASK_LIST; class task_list { public:   task_list();   virtual ~task_list();   void append_task(task_info* tsk);   task_info* fetch_task(); private:   TASK_LIST m_tasklist;   locker m_lk;   sem_t m_sem; }; #endif /* TASK_LIST_H_ */

文件名:task_list.cpp

#include "task_list.h" task_list::task_list() {   // Init Semaphore   sem_init(&m_sem, 0, 0);   m_tasklist.clear(); } task_list::~task_list() {   while(!m_tasklist.empty())   {     task_info* tr = m_tasklist.front();     m_tasklist.pop_front();     if(tr)       delete tr;   }   // Destroy Semaphore   sem_destroy(&m_sem); } void task_list::append_task(task_info* tsk) {   // Lock before Modify the list   m_lk.lock();   m_tasklist.push_back(tsk);   m_lk.unlock();   // Increase the Semaphore   sem_post(&m_sem); } task_info* task_list::fetch_task() {   task_info* tr = NULL;   sem_wait(&m_sem);   m_lk.lock();   tr = m_tasklist.front();   m_tasklist.pop_front();   m_lk.unlock();   return tr; }

文件名:thread_pool.h

#ifndef THREAD_POOL_H_ #define THREAD_POOL_H_ #include "task_list.h" #include "pthread.h" #define DEFAULT_THREAD_COUNT  4 #define MAXIMUM_THREAD_COUNT  1000 class thread_pool { public:   thread_pool();   virtual ~thread_pool();   int create_threads(int n = DEFAULT_THREAD_COUNT);   void delete_threads();   void set_tasklist(task_list* plist);   void del_tasklist(); protected:   static void* thread_func(void* parm);   task_info* get_task(); private:   int       m_thread_cnt;   pthread_t    m_pids[MAXIMUM_THREAD_COUNT];   task_list*   m_tasklist; }; #endif /* THREAD_POOL_H_ */ 

文件名:thread_pool.cpp

#include "thread_pool.h" thread_pool::thread_pool() {   m_thread_cnt = 0;   m_tasklist = NULL; } thread_pool::~thread_pool() {   delete_threads(); } task_info* thread_pool::get_task() {   task_info* tr;   if (m_tasklist)   {     tr = m_tasklist->fetch_task();     return tr;   }   return NULL; } void* thread_pool::thread_func(void* parm) {   thread_pool *ptp = static_cast<thread_pool*> (parm);   task_info *task;   while (true)   {     task = ptp->get_task();     if (task)     {       (*task->func)(task);       //delete task; //func負責釋放task_info     }   }   return NULL; } int thread_pool::create_threads(int n) {   if (n > MAXIMUM_THREAD_COUNT)     n = MAXIMUM_THREAD_COUNT;   delete_threads();   for (int i = 0; i < n; i++)   {     int ret = pthread_create(&m_pids[i], NULL, thread_func, (void*) this);     if (ret != 0)       break;     m_thread_cnt++;   }   return m_thread_cnt; } void thread_pool::delete_threads() {   for (int i = 0; i < m_thread_cnt; i++)   {     void* retval;     pthread_cancel(m_pids[i]);     pthread_join(m_pids[i], &retval);   }   m_thread_cnt = 0; } void thread_pool::set_tasklist(task_list* plist) {   m_tasklist = plist; } void thread_pool::del_tasklist() {   m_tasklist = NULL; }

文件名:test.cpp

#include "unistd.h" #include "stdio.h" #include "stdlib.h" #include "task_list.h" #include "thread_pool.h" void* fun(void *parm) {   task_info* ptk = (task_info*)parm;   pid_t tid = pthread_self();   int count = (int)ptk->parm0;   printf("count=%d, tid=%d/n", count, tid);   return NULL; } int main() {   int count = 0;   thread_pool tp;   task_list tl;   tp.create_threads(4 - 1);   tp.set_tasklist(&tl);   while (1)   {     task_info* pti = NULL;     pti = (task_info *) malloc(sizeof(task_info));     pti->func = fun;     pti->parm0 = (void *)count;     tl.append_task(pti);     count++;     sleep(2);   } // printf("hello,world/n");   return 0; } 

編譯運行,我是用ecplise建立的automake工程,所以只要修改一下Makefile.am就可以編譯成功了
文件名:Makefile.am

bin_PROGRAMS=test test_SOURCES=test.cpp locker.h locker.cpp /               task_list.h task_list.cpp /               thread_pool.h thread_pool.cpp test_LDADD=-lpthread 

執行結果:

count=0, tid=-1219888272 count=1, tid=-1219888272 count=2, tid=-1228280976 count=3, tid=-1236673680 count=4, tid=-1219888272 count=5, tid=-1228280976 count=6, tid=-1236673680 count=7, tid=-1219888272 count=8, tid=-1228280976 count=9, tid=-1236673680 

希望本文所述對大家的C++程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲欧美日韩精品久久| 国产69精品久久久久9999| 欧美精品福利视频| 精品视频久久久久久| 国产精品久久视频| 456国产精品| 国产成人精品网站| 国产欧美日韩视频| 国产99在线|中文| 91中文精品字幕在线视频| 中文字幕日本欧美| 国产+人+亚洲| 亚洲一区二区三区777| 国产一区二区视频在线观看| 国产免费一区二区三区在线能观看| 亚洲网站在线观看| 成人高h视频在线| 国产精品老女人视频| 一区二区三区视频免费| 亚洲色图校园春色| 国产精品日韩在线播放| 欧美综合在线第二页| 欧美在线视频网站| 成人午夜在线观看| 久久大大胆人体| 少妇高潮久久77777| 中文字幕欧美日韩在线| 久久久久久这里只有精品| 国产精品视频999| 国产日韩换脸av一区在线观看| 欧美又大粗又爽又黄大片视频| 亚洲欧美一区二区精品久久久| 91最新在线免费观看| 国产999精品久久久| 久久这里有精品视频| 91国在线精品国内播放| 中文字幕日韩在线观看| 亚洲欧美综合区自拍另类| 国产精品丝袜高跟| 97香蕉超级碰碰久久免费的优势| 亚洲国产精品高清久久久| 深夜福利日韩在线看| 久久综合久中文字幕青草| 亚洲电影中文字幕| 国产精品久久久久久亚洲调教| www.日韩av.com| 日韩精品丝袜在线| 亚洲男人天堂2024| 成人福利视频网| 亚洲高清在线观看| 欧美成年人视频网站欧美| 亚洲成人动漫在线播放| 国产在线拍揄自揄视频不卡99| 亚洲精品天天看| 九九热这里只有在线精品视| 国产精品久久久久久久9999| 青草青草久热精品视频在线观看| 欧美电影免费观看高清完整| 中文字幕最新精品| 茄子视频成人在线| 国产啪精品视频网站| 亚洲国产美女久久久久| 国产精品久久久久久久美男| 一区二区欧美日韩视频| 国产亚洲日本欧美韩国| 在线观看亚洲区| 欧美大片免费观看在线观看网站推荐| 精品自拍视频在线观看| 久久精品亚洲一区| 一区二区亚洲精品国产| 亚洲精品免费网站| 国产精品久久77777| 不卡av在线播放| 亚洲免费中文字幕| 日韩av手机在线观看| 成人羞羞国产免费| 国产69精品久久久久9| 日韩欧美亚洲范冰冰与中字| 综合136福利视频在线| 久久亚洲综合国产精品99麻豆精品福利| 激情懂色av一区av二区av| 亚洲国内精品视频| 色综合导航网站| 97av在线播放| 国产在线不卡精品| 中文字幕精品在线| 日韩在线视频二区| www.午夜精品| 国产精品高清在线| 97视频在线观看播放| 日韩av中文字幕在线| 亚洲精品国产福利| 色在人av网站天堂精品| 国产精品av在线播放| 5278欧美一区二区三区| 日韩大陆毛片av| 国产日产欧美精品| 国产97在线视频| 欧美成人在线网站| 最近2019中文字幕第三页视频| 亚洲国产成人精品女人久久久| 国产精品久久久久久久久久东京| 91亚洲国产成人精品性色| 国产精品久久久久7777婷婷| 55夜色66夜色国产精品视频| 日韩av一卡二卡| 亚洲精品久久视频| 亚洲综合在线小说| 久久91超碰青草是什么| 国产精品高潮呻吟久久av野狼| 欧美xxxx综合视频| 欧美色视频日本高清在线观看| 日本不卡视频在线播放| 992tv成人免费视频| 九色精品免费永久在线| 久久久99免费视频| 97精品久久久| 欧美电影免费观看| 91在线观看免费高清完整版在线观看| 国产欧美精品一区二区三区介绍| 欧洲日本亚洲国产区| 91精品国产自产91精品| 日韩av网站电影| 国产欧美日韩高清| 日韩视频免费看| 中文字幕自拍vr一区二区三区| 亚洲精品一区二区三区婷婷月| 国产精品v片在线观看不卡| 亚洲伊人久久综合| 日韩电影免费观看在线观看| 97国产suv精品一区二区62| 91日韩在线视频| 亚洲精品免费av| 亚洲一级一级97网| 久久久伊人日本| 国产精品老女人精品视频| 欧美激情国产高清| 成人在线视频网站| 国产精品aaa| 97在线精品国自产拍中文| 亚洲最大福利网| 成人精品一区二区三区电影免费| 欧美成人免费播放| 欧美男插女视频| 国产综合久久久久久| 亚洲午夜精品久久久久久性色| 欧美在线视频免费播放| 欧美夜福利tv在线| 日韩精品福利网站| 69av在线播放| 欧美寡妇偷汉性猛交| 国产精品一区二区三| 亚洲女人天堂视频| 欧美另类极品videosbest最新版本| 亚洲成人黄色在线| 欧美性理论片在线观看片免费| 国产精品久久久久久久美男| 亚洲毛片在线免费观看| 51精品国产黑色丝袜高跟鞋| 亚洲国产精品国自产拍av秋霞| 3344国产精品免费看| 亚洲黄色www| 亚洲国产精品专区久久| 欧美日韩美女在线|