我们在使用一个软件的时候,可能这个软件同时在进行着下载任务和播放
任务,以及其他后台我们看不到的任务,其实这种现象就是使用多线程实
现的,但是我们知道在创建线程的时候,操作系统要为我们做好一系列准
备工作才能将线程创建好,所以为了我们的进程在需要线程处理任务的时
候,我们要确保线程早就已经准备好了,而这种技术也叫做池化技术,今
天我就来介绍一下如何在Linux下封装一个简单的线程池。
1. 前置准备
在封装线程池之前,我们要知道,Linux是C语言写的,那就意味着它的封装性是没有体现出来的,它的系统调用用起来是有些麻烦的,所以在这里我对要创建线程池的接口用C++进行了简单的封装,以便能够提高编码效率。
首先是pthread库中线程创建以及控制函数的封装:
标题:一小段代码
然后是对pthread中互斥量的创建及使用的封装:
标题:局部变量的锁
还有就是加了日志功能,进行简单的Debug:
日志代码
那么了解过以上代码之后我们就可以开始来封装一个线程池了。
2. 大致介绍
那么我们要实现一个什么样的线程池呢?
其实这就有点像生产消费者模型了,不太了解该模型可以看一下我的另一篇博客:标题:生产消费者模型。
3. 线程池的封装
现在我们就可以根据上面的图来封装线程池了。
首先我们的线程池里一定要有的几个元素:队列、若干线程、一个整型(表示创建几个线程)。
知道CP模型的话,就知道负责解决任务的这几个线程之间是互斥的,并且发送任务的这个执行流处理任务的那几个线程是互斥且同步的,所以我们还需要一把锁(只有一个共享资源:任务队列)和一个条件变量(当队列为空时,进行处理任务的线程要在条件变量下等待,防止过度申请锁资源):
那么现在我们就需要先写好线程池的构造和析构函数:
然后就是执行流能够传输任务到任务队列:
然后就是线程处理任务的函数:
解决了任务的输送问题,最后就剩下一个让线程池跑起来,以及销毁线程池中的线程:
现在我们这个线程池就完成了,我们现在可以使用这个线程池来解决任务了,我在这里写一个简单的任务类:
执行任务:
为了更直观的看到线程在解决任务,我们使用日志功能:
至此,一个简单的线程池就完成了。