本文记录了在linux环境下分别使用C和C++语言实现线程池的过程,并附带源码和解析。
文章目录
一、线程池理论知识
1.1什么是线程池
线程池(thread pool): 一种线程使用模式,线程过多会带来调度开销,进而影响缓存局部性和整体性能。而线程池维护着多个线程,等待着监督管理者分配可并发执行的任务。这避免了在短时间任务创建与销毁线程的代价。线程池不仅能够保证内核的充分利用,还能防止过分调度。可用线程数据取决于可用的并发处理器、处理器内核、内存、网络sockets等数量。
因为程序边运行边创建线程是比较耗时的,所以我们通过池化的思想:在程序开始运行前创建多个线程这样,程序在运行时,只需要从线程池中拿来用就可以了.大大提高了程序运行效率。
举个通俗的例子来解释线程池:
就拿老板找员工干活举例子,不用线程池的话 ,就相当于每次到了有外包任务过来,老板就要招一个员工去做,需要经历发布招工信息、面试、谈薪资等过程,等任务干完了就把该员工辞退了。如果用线程池的话就是,你可以提前一次性招几个员工一起做任务,把任务按需分配给这几个人,活少的时候可能这几个人会闲着,但是活多的时候可以让这几个人排队一直干活。这样就节省了每次都发布招工信息、面试、谈薪资等时间开销。
1.2 使用线程池的好处
-
降低资源消耗。通过重复利用已创建的线程降低线程创建和销毁造成的消耗。
-
提高响应速度