Linux——线程池

本文介绍了如何在Linux环境下使用C++封装线程池,基于生产消费者模型,涉及线程创建、互斥控制、任务队列管理,以及使用日志功能进行调试。
摘要由CSDN通过智能技术生成
我们在使用一个软件的时候,可能这个软件同时在进行着下载任务和播放
任务,以及其他后台我们看不到的任务,其实这种现象就是使用多线程实
现的,但是我们知道在创建线程的时候,操作系统要为我们做好一系列准
备工作才能将线程创建好,所以为了我们的进程在需要线程处理任务的时
候,我们要确保线程早就已经准备好了,而这种技术也叫做池化技术,今
天我就来介绍一下如何在Linux下封装一个简单的线程池。

1. 前置准备

在封装线程池之前,我们要知道,Linux是C语言写的,那就意味着它的封装性是没有体现出来的,它的系统调用用起来是有些麻烦的,所以在这里我对要创建线程池的接口用C++进行了简单的封装,以便能够提高编码效率。
首先是pthread库中线程创建以及控制函数的封装:
标题:一小段代码
然后是对pthread中互斥量的创建及使用的封装:
标题:局部变量的锁
还有就是加了日志功能,进行简单的Debug:
日志代码
那么了解过以上代码之后我们就可以开始来封装一个线程池了。

2. 大致介绍

那么我们要实现一个什么样的线程池呢?
在这里插入图片描述
其实这就有点像生产消费者模型了,不太了解该模型可以看一下我的另一篇博客:标题:生产消费者模型

3. 线程池的封装

现在我们就可以根据上面的图来封装线程池了。
首先我们的线程池里一定要有的几个元素:队列、若干线程、一个整型(表示创建几个线程)。
知道CP模型的话,就知道负责解决任务的这几个线程之间是互斥的,并且发送任务的这个执行流处理任务的那几个线程是互斥且同步的,所以我们还需要一把锁(只有一个共享资源:任务队列)和一个条件变量(当队列为空时,进行处理任务的线程要在条件变量下等待,防止过度申请锁资源):
在这里插入图片描述

那么现在我们就需要先写好线程池的构造和析构函数:
在这里插入图片描述
然后就是执行流能够传输任务到任务队列:
在这里插入图片描述
然后就是线程处理任务的函数:
在这里插入图片描述
解决了任务的输送问题,最后就剩下一个让线程池跑起来,以及销毁线程池中的线程:
在这里插入图片描述
现在我们这个线程池就完成了,我们现在可以使用这个线程池来解决任务了,我在这里写一个简单的任务类:
在这里插入图片描述
执行任务:
在这里插入图片描述
在这里插入图片描述
为了更直观的看到线程在解决任务,我们使用日志功能:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
至此,一个简单的线程池就完成了。

  • 8
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值