Linux下设计一个简单的线程池.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Linux下设计一个简单的线程池

Linux下设计一个简单的线程池 定义 什么是线程池?简单点说,线程池就是有一堆已经创建好了的线程,初始它们都处于空闲等待状态,当有新的任务需要处理的时候,就从这个池子里面取一个空闲等待的线程来处理该任务,当处理完成了就再次把该线程放回池中,以供后面的任务使用。当池子里的线程全都处理忙碌状态时,线程池中没有可用的空闲等待线程,此时,根据需要选择创建一个新的线程并置入池中,或者通知任务线程池忙,稍后再试。 为什么要用线程池? 我们说,线程的创建和销毁比之进程的创建和销毁是轻量级的,但是当我们的任务需要大量进行大量线程的创建和销毁操作时,这个消耗就会变成的相当大。比如,当你设计一个压力性能测试框架的时候,需要连续产生大量的并发操作,这个是时候,线程池就可以很好的帮上你的忙。线程池的好处就在于线程复用,一个任务处理完成后,当前线程可以直接处理下一个任务,而不是销毁后再创建,非常适用于连续产生大量并发任务的场合。 线程池工作原理 线程池中每一个线程的工作过程如下: 图 1: 线程的工作流程 线程池的任务就在于负责这些线程的创建,销毁和任务处理参数传递、唤醒和等待。 1. 创建若干线程,置入线程池 2. 任务达到时,从线程池取空闲线程 3. 取得了空闲线程,立即进行任务处理 4. 否则新建一个线程,并置入线程池,执行3 5. 如果创建失败或者线程池已满,根据设计策略选择返回错误或将任务置入处理队列,等待处理 6. 销毁线程池 图 2:线程池的工作原理 线程池设计数据结构设计任务设计 view plaincopy to clipboardprint? typedef struct tp_work_desc_s TpWorkDesc; typedef void (*process_job)(TpWorkDesc*job); struct tp_work_desc_s { void *ret; //call in, that is arguments void *arg; //call out, that is return value }; 其中,TpWorkDesc是任务参数描述,arg是传递给任务的参数,ret则是任务处理完成后的返回值; process_job函数是任务处理函数原型,每个任务处理函数都应该这样定义,然后将它作为参数传给线程池处理,线程池将会选择一个空闲线程通过调用该函数来进行任务处理; 线程设计 view plaincopy to clipboardprint? typedef struct tp_thread_info_s TpThreadInfo; struct tp_thread_info_s { pthread_t thread_id; //thread id num TPBOOL is_busy; //thread status:true-busy;flase-idle pthread_cond_t thread_cond; pthread_mutex_t thread_lock; process_job proc_fun; TpWorkDesc* th_job; TpThreadPool* tp_pool; }; TpThreadInfo是对一个线程的描述。 thread_id是该线程的ID; is_busy用于标识该线程是否正处理忙碌状态; thread_cond用于任务处理时的唤醒和等待; thread_lock,用于任务加锁(此处保留); proc_fun是当前任务的回调函数地址; th_job是任务的参数信息; tp_pool是所在线程池的指针; 线程池设计 view plaincopy to clipboardprint? typedef struct tp_thread_pool_s TpThreadPool; struct tp_thread_pool_s { unsigned min_th_num; //min thread number in the pool unsigned cur_th_num; //current thread number in the pool unsigned max_th_num; //max thre

文档评论(0)

xcs88858 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档