青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

我的程序人生

c++ 線程池的實現(xiàn)(原)

看群里有同志老是在找線程池的實現(xiàn),聽說網(wǎng)上曾經(jīng)發(fā)布的都是不正確的,今天我就自己弄了一個,不正確的地方大家指點指點

mutex.hxx 互斥類
 1#ifndef INCLUDE_MUTEX_HH
 2#define INCLUDE_MUTEX_HH
 3#include <pthread.h>
 4
 5class Mutex
 6{
 7public:
 8  Mutex();
 9  virtual ~Mutex();
10  void lock();
11  void unlock();
12  pthread_mutex_t *get_mutex();
13private:
14  pthread_mutex_t mutex;
15}
;
16
17#endif
18

mutex.cxx互斥實現(xiàn)類
#include "mutex.hxx"
#include 
"error.hxx"
Mutex::Mutex()
{
  
if(pthread_mutex_init(&mutex,NULL))
    
{
      perror(
"pthread_mutex_init error");
      
throw MutexError("pthread_mutex_init error");
    }

}

Mutex::
~Mutex()
{
  
if(pthread_mutex_destroy(&mutex))
    
{
      perror(
"pthread_mutex_destroy error");
      
throw MutexError("pthread_mutex_destroy error");
    }

}


void Mutex::lock()
{
  pthread_mutex_lock(
&mutex);
}


void Mutex::unlock()
{
  pthread_mutex_unlock(
&mutex);
}


pthread_mutex_t 
*Mutex::get_mutex()
{
  
return &mutex;
}


error.hxx 異常類型
#ifndef INCLUDE_ERROR_HH
#define INCLUDE_ERROR_HH
#include 
<stdexcept>

class MutexError:public std::runtime_error
{
public:
  MutexError(
const std::string& what)
    :std::runtime_error(what.c_str())
  
{}
  MutexError(
const char* const what)
    :std::runtime_error(what)
  
{}
}
;

#endif

task.hxx 任務(wù)類,所有的任務(wù)需要實現(xiàn)此接口
#ifndef INCLUDE_TASK_HH
#define INCLUDE_TASK_HH

#include 
<string>
#include 
"mutex.hxx"
//class Mutex;
class Task
{
  friend 
bool operator<(const Task& t1,const Task& t2);
public:
  Task(
const std::string& taskName=std::string(),int level=0);
  
virtual ~Task(){};
  
void setLevel(int level);
  std::
string taskName()const;
  std::
string taskName();
  
void setName(const std::string&);
  
virtual void run()=0;

private:
  Mutex mutex;
  
int level_;
  std::
string taskName_;

}
;
#endif

task.cxx 任務(wù)實現(xiàn)代碼
#include "task.hxx"
//#include "mutex.hxx"

Task::Task(
const std::string& name,int level)
  :taskName_(name),level_(level)
{
}


void Task::setLevel(int level)
{
  mutex.
lock();
  level_
=level;
  mutex.unlock();
}

std::
string Task::taskName()const
{
  
return taskName_;
}

std::
string Task::taskName()
{
  
return taskName_;
}

void Task::setName(const std::string& name)
{
  mutex.
lock();
  taskName_
=name;
  mutex.unlock();
}

bool operator<(const Task& t1,const Task& t2)
{
  
return t1.level_<t2.level_;
}


池頭文件 pool.hxx
#ifndef INCLUDE_POOL_HH
#define INCLUDE_POOL_HH
#include 
<pthread.h>
#include 
<queue>
#include 
<list>
#include 
"mutex.hxx"
class Task;
class ThreadPool
  :
private Mutex
{
public:
  ThreadPool(
int);
  
~ThreadPool();
  
void addTask(Task*);
  
void wait();
  
void release(const pthread_t&);
  Task
* get();
  
void setTimeout(long t);
private:
  typedef std::list
<pthread_t>::iterator ThreadIterator;
  pthread_cond_t release_cond;
  pthread_cond_t task_cond;
  
static void* threadFunc(void*);
  
void init(int);
  std::priority_queue
<Task*> tasks;
  std::list
<pthread_t> idleThreads;
  std::list
<pthread_t> busyThreads;
  
long timeout_second;
}
;

#endif

池實現(xiàn)文件
#include "pool.hxx"
#include 
"task.hxx"
#include 
<algorithm>
#include 
<ctime>
#include 
<iostream>

ThreadPool::ThreadPool(
int threadNumber)
  :timeout_second(
10)
{
  pthread_cond_init(
&release_cond,NULL);
  pthread_cond_init(
&task_cond,NULL);
  init(threadNumber);
}


ThreadPool::
~ThreadPool()
{
  pthread_cond_destroy(
&release_cond);
  pthread_cond_destroy(
&task_cond);
}


void ThreadPool::init(int threadNumber)
{
  
for(int i=0;i<threadNumber;i++)
    
{
      pthread_t t;
      pthread_create(
&t,NULL,threadFunc,this);
      busyThreads.push_back(t);
    }

}


void ThreadPool::setTimeout(long t)
{
  
if(t>0)
    timeout_second
=t;
}


void ThreadPool::addTask(Task* task)
{
  
lock();
  tasks.push(task);
  pthread_cond_signal(
&task_cond);
  unlock();
}


Task
* ThreadPool::get()
{
  
struct timespec timeout;
  timeout.tv_sec
=time(NULL)+timeout_second;
  timeout.tv_nsec
=0;
  
lock();
  
if(tasks.empty())
    
{
      pthread_cond_timedwait(
&task_cond,get_mutex(),&timeout);
    }

  
if(tasks.empty())
    
{
      std::cout
<<"empty"<<std::endl;
      unlock();
      
return NULL;
    }

  Task 
*task=tasks.top();
  tasks.pop();
  unlock();
  
return task;
}


void * ThreadPool::threadFunc(void* args)
{
  ThreadPool
* pool=static_cast<ThreadPool*>(args);
  Task
* task;
  
while((task=pool->get())!=NULL)
    
{
      task
->run();
    }

  pool
->release(pthread_self());
}


void ThreadPool::release(const pthread_t& t)
{
  
lock();
  ThreadIterator it;
  it
=std::find(busyThreads.begin(),busyThreads.end(),t);
  
if(it!=busyThreads.end())
    
{
      busyThreads.erase(it);
    }

  idleThreads.push_back(t);
  pthread_cond_signal(
&release_cond);
  unlock();
}

void ThreadPool::wait()
{
  
lock();
  
while(!busyThreads.empty())
    
{
      
struct timespec timeout;
      timeout.tv_sec
=time(NULL)+10;
      timeout.tv_nsec
=0;

      pthread_cond_timedwait(
&release_cond,get_mutex(),&timeout);
    }


  
for(ThreadIterator it=idleThreads.begin();it!=idleThreads.end();it++)
    
{
      pthread_join(
*it,NULL);
    }

  unlock();
  
}



測試文件
#include "pool.hxx"
#include 
"task.hxx"
#include 
<unistd.h>
#include 
<iostream>
#include 
<string>
#include 
<vector>
#include 
<sstream>
#include 
<memory>
#include 
"mutex.hxx"
class WorkTask
  :
public Task
{
public:
  WorkTask(
int level,void *data):Task(std::string(),level)
  
{
    
this->data_=data;
  }

  
~WorkTask(){}
  
virtual void run()
  
{
    std::cout
<<taskName()<<(char*)data_<<std::endl;
    sleep(
2);
    std::cout
<<taskName()<<" ok"<<std::endl;
  }

private:
  
void *data_;
  Mutex mutex;
}
;

int main(void)
{
  ThreadPool pool(
5);
  
char szTemp[]="aaaaaaaaaaaaaaabbbbbbbbbbbccccccccccdddddddddd";
  WorkTask task(
1,szTemp);
  
char buf[20];
  std::vector
<Task*> tasks;
  
for(int i=0;i<10;i++)
    
{
      snprintf(buf,
sizeof(buf),"%s %d","task",i);
      task.setName(buf);
      std::auto_ptr
<Task> t(new WorkTask(task));
      pool.addTask(t.
get());
      tasks.push_back(t.release());
    }

  pool.wait();
  
for(std::vector<Task*>::iterator it=tasks.begin();it!=tasks.end();it++)
    
{
      delete 
*it;
    }

  
return 0;
}





測試的結(jié)果


沒有注釋直接看源碼就可解決。。


注:使用本人代碼請注明本人的信息

posted on 2010-04-08 15:43 lancey 閱讀(7276) 評論(9)  編輯 收藏 引用

Feedback

# re: c++ 線程池的實現(xiàn)(原) 2010-04-08 18:02 oh no

永遠(yuǎn)不要在析構(gòu)函數(shù)拋出異常。  回復(fù)  更多評論   

# re: c++ 線程池的實現(xiàn)(原)[未登錄] 2010-04-08 20:52 OnTheWay

#include <pthread.h> 這個文件是系統(tǒng)的嗎,還是你寫的?  回復(fù)  更多評論   

# re: c++ 線程池的實現(xiàn)(原) 2010-04-08 22:58 ChowZenki

@OnTheWay
那是linux的頭文件  回復(fù)  更多評論   

# re: c++ 線程池的實現(xiàn)(原) 2010-04-09 02:49 欲三更

兩點不同意見:

1.
Mutex::~Mutex()
{
...
throw MutexError("pthread_mutex_destroy error");
...
}

這個絕對不可以有。。。

2.我覺得lock和unlock之間的代碼不安全,如果拋出異常可能導(dǎo)致死鎖。

  回復(fù)  更多評論   

# re: c++ 線程池的實現(xiàn)(原) 2010-04-09 11:39 china_zhli@163.com

@oh no
用代碼說明  回復(fù)  更多評論   

# re: c++ 線程池的實現(xiàn)(原) 2010-04-09 16:33 lancey

其實我也是不打算讓mutex的構(gòu)造與析構(gòu)時異常拋出,只是想在連互斥量都無法初始化與銷毀時我直接abort或不處理都感覺不好,才這樣做,留給調(diào)用者處理
  回復(fù)  更多評論   

# re: c++ 線程池的實現(xiàn)(原) 2010-04-09 17:31 路過

垃圾實現(xiàn),去看看ACE或apr實現(xiàn)再來吧,哎  回復(fù)  更多評論   

# re: c++ 線程池的實現(xiàn)(原) 2010-04-13 02:06 欲三更

@路過
回訪,容我說一句,lz這個東西寫的確實不夠好,這個不用看高超的實現(xiàn)就能判斷。簡單的說就是這個實現(xiàn)“不能用”。但是也不能說是垃圾吧?至少lz寫的代碼整整齊齊,沒有注釋也很容易看懂,基本方法也對。

“垃圾”這種說法,還是盡量別出現(xiàn)在這個站點比較好。  回復(fù)  更多評論   

# re: c++ 線程池的實現(xiàn)(原) 2010-04-13 02:07 欲三更

@路過
ps:apr真的是做得很好:)  回復(fù)  更多評論   



只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


My Links

Blog Stats

常用鏈接

留言簿(2)

隨筆檔案

文章分類

文章檔案

我的鏈接

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            99re8这里有精品热视频免费| 欧美成va人片在线观看| 久久精品五月| 亚洲日本成人女熟在线观看| 欧美日本精品一区二区三区| 午夜免费电影一区在线观看| 久久人91精品久久久久久不卡 | 免费日韩成人| 亚洲无线一线二线三线区别av| 久久婷婷一区| 亚洲视频免费| 1204国产成人精品视频| 欧美特黄一级大片| 久久一区二区精品| 亚洲特黄一级片| 亚洲国产精选| 久久这里有精品视频| 亚洲性色视频| 亚洲肉体裸体xxxx137| 国产网站欧美日韩免费精品在线观看| 欧美高清视频在线观看| 久久精品国产第一区二区三区最新章节 | 日韩网站在线| 欧美aa在线视频| 欧美综合二区| 亚洲小说区图片区| 亚洲国产你懂的| 国产精品无码永久免费888| 美女精品视频一区| 久久se精品一区精品二区| 正在播放亚洲一区| 亚洲伦理在线免费看| 亚洲福利视频网站| 久久综合激情| 久久久精品五月天| 欧美一区日韩一区| 亚洲性色视频| 亚洲一区免费在线观看| 亚洲另类一区二区| 亚洲精品久久久久久久久久久久久| 黄色成人精品网站| 国产综合色产在线精品| 亚洲欧洲一级| 亚洲国产第一| 亚洲福利视频一区二区| 牛牛影视久久网| 久久成人精品视频| 欧美一区二区三区在线观看| 午夜精品成人在线| 午夜精品久久久久久 | 欧美在线观看视频一区二区三区| 99re热这里只有精品视频| 亚洲精品在线观| 亚洲人成高清| 99视频精品在线| 一区二区不卡在线视频 午夜欧美不卡'| 悠悠资源网久久精品| 亚洲成色最大综合在线| 国产亚洲精品久久久久动| 国产精品美女久久| 国产精品久久久久婷婷| 国产精品色网| 狠狠噜噜久久| 亚洲福利小视频| 亚洲精品欧美精品| 中文欧美在线视频| 欧美一区二区三区在线观看视频 | 亚洲一区二区黄| 亚洲欧美日韩天堂一区二区| 99精品欧美一区二区蜜桃免费| 一区二区三区四区五区视频 | 麻豆精品传媒视频| 欧美电影在线免费观看网站| 欧美日本一区二区三区| 欧美日韩综合一区| 国产女人18毛片水18精品| 国产综合av| 亚洲激情影视| 亚洲黄色av一区| 亚洲网站在线播放| 久久国产日本精品| 欧美粗暴jizz性欧美20| 日韩视频一区| 欧美一区二区视频免费观看| 久久综合给合久久狠狠色| 欧美精品久久天天躁| 国产女主播一区二区三区| 在线成人www免费观看视频| 日韩一级免费观看| 欧美伊人久久久久久午夜久久久久| 久久久久久亚洲精品杨幂换脸| 亚洲电影第三页| 亚洲一区二区在线免费观看视频 | 亚洲欧美韩国| 久久三级福利| 亚洲麻豆av| 欧美中文字幕不卡| 欧美日韩精品一区| 国外精品视频| 欧美日本一道本| 国产亚洲精品久| 亚洲欧洲在线一区| 欧美一区二区高清在线观看| 亚洲高清在线视频| 新67194成人永久网站| 久久久久国产免费免费| 欧美日韩另类视频| 激情国产一区二区| 99视频一区二区三区| 久热这里只精品99re8久| 日韩午夜av| 免费亚洲电影| 国产视频欧美视频| 一本色道久久加勒比88综合| 久久嫩草精品久久久精品| 一区二区国产日产| 免费不卡亚洲欧美| 国产综合一区二区| 午夜久久黄色| 日韩一级不卡| 欧美成人网在线| 国产视频久久久久| 亚洲综合首页| 欧美第十八页| 午夜久久福利| 欧美日韩免费看| 日韩亚洲在线观看| 欧美激情中文字幕在线| 久久亚洲精品中文字幕冲田杏梨| 国产美女一区| 西瓜成人精品人成网站| 99re6这里只有精品视频在线观看| 久久嫩草精品久久久久| 国产综合色精品一区二区三区| 欧美一级午夜免费电影| aa成人免费视频| 欧美日韩亚洲一区二| 在线视频欧美日韩| 久久综合九色综合久99| 一区二区三区产品免费精品久久75| 欧美激情中文字幕乱码免费| 亚洲国产精品传媒在线观看| 麻豆精品视频在线| 久久电影一区| 在线成人中文字幕| 久久久久欧美| 亚洲欧美日本伦理| 国产精品日韩精品欧美在线| 亚洲男人第一av网站| 一本久久a久久免费精品不卡| 欧美人与性禽动交情品| 亚洲精品一区二区三区av| 欧美激情导航| 欧美激情视频一区二区三区免费 | 欧美精品一区二区三区在线看午夜 | 国产日韩欧美日韩| 久久久久久久波多野高潮日日| 亚洲欧美福利一区二区| 欧美日韩第一区日日骚| 亚洲私人影吧| 亚洲女人天堂av| 黑丝一区二区| 欧美激情精品| 欧美日韩中文精品| 性久久久久久久| 欧美一区二区三区喷汁尤物| 在线观看久久av| 99re成人精品视频| 亚洲欧美日韩视频一区| 亚洲第一区中文99精品| 日韩午夜电影在线观看| 国产一区二区欧美日韩| 亚洲激情第一区| 国产欧美日韩在线播放| 亚洲国产mv| 国产一区二区三区在线观看视频| 亚洲国产精品一区在线观看不卡| 国产精品狼人久久影院观看方式| 牛牛精品成人免费视频| 国产精品久久久久77777| 另类成人小视频在线| 欧美系列亚洲系列| 欧美成人黄色小视频| 国产精品久久毛片a| 欧美成人一区二免费视频软件| 国产精品九九| 亚洲经典在线看| 国产一区二区三区久久久久久久久| 亚洲日本中文字幕免费在线不卡| 国产日韩综合| 夜夜精品视频| 亚洲九九精品| 久久久久**毛片大全| 亚洲自拍偷拍色片视频| 欧美成人一区二区三区| 久久久999精品视频| 欧美丝袜一区二区三区| 亚洲国产一区二区三区在线播 | 欧美无乱码久久久免费午夜一区 | 一本一本久久a久久精品综合麻豆 一本一本久久a久久精品牛牛影视 |