线程池的原理
一 线程池的作用
1.减少线程的创建和销毁。线程的创建和销毁比较消耗计算机资源,使用线程池可以很好的避免消耗这些资源。
2.异步解耦的作用。使用线程池,可以帮助开发人员专注于任务,不用考虑线程是如何执行的,实现任务提交和执行的解耦。
二 工作原理
线程池有两个部分组成:
1.任务队列。任务队列是需要完成的任务组成的队列。
2.执行队列。执行队列是由一群已经存在的线程组成的队列,它负责执行从任务队列中取得的任务。当任务执行完毕时,就从任务队列中取得新的任务去执行;当任务队列中没有新任务时,就阻塞本线程。
用户使用线程池的过程就是向任务队列里添加任务的过程。
线程池的三个重要的函数:
1.thread_pool_create 线程初始化的函数
2.thread_callback 线程从任务队列中取任务并执行的函数
3.thread_pool_push_job 向线程抛任务的函数
三 nginx线程池
nginx线程池初始化的函数:ngx_thread_pool_init
向线程池抛队列的函数:ngx_thread_task_post
四 线程池的代码实现
这是我用C语言实现的简易线程池:
链接: https://github.com/q962875152/mycode/blob/master/threadpool.c