我们在使用一个软件的时候,可能这个软件同时在进行着下载任务和播放
任务,以及其他后台我们看不到的任务,其实这种现象就是使用多线程实
现的,但是我们知道在创建线程的时候,操作系统要为我们做好一系列准
备工作才能将线程创建好,所以为了我们的进程在需要线程处理任务的时
候,我们要确保线程早就已经准备好了,而这种技术也叫做池化技术,今
天我就来介绍一下如何在Linux下封装一个简单的线程池。
1. 前置准备
在封装线程池之前,我们要知道,Linux是C语言写的,那就意味着它的封装性是没有体现出来的,它的系统调用用起来是有些麻烦的,所以在这里我对要创建线程池的接口用C++进行了简单的封装,以便能够提高编码效率。
首先是pthread库中线程创建以及控制函数的封装:
标题:一小段代码
然后是对pthread中互斥量的创建及使用的封装:
标题:局部变量的锁
还有就是加了日志功能,进行简单的Debug:
日志代码
那么了解过以上代码之后我们就可以开始来封装一个线程池了。
2. 大致介绍
那么我们要实现一个什么样的线程池呢?

其实这就有点像生产消费者模型了,不太了解该模型可以看一下我的另一篇博客:
Linux下的C++线程池封装与生产者消费者模型应用

最低0.47元/天 解锁文章
835

被折叠的 条评论
为什么被折叠?



