【精简】线程池的概念和实现方法

1 初始化一些线程

  1. 管理者线程
    不处理任务
  2. 工作的线程
    只负责处理任务
    去任务队列中领任务并处理
  3. 初始化的时候给定一个最小线程数

2 需要有一个管理者线程

  1. 每隔一段时间去判断一次
  2. 什么时候需要创建
    指定一个峰值:工作的线程超过85%,工作/存活 > 0.85
    超过峰值:创建新的线程 每次创建一部分待用,按照一定的步长和比例去创建
  3. 什么时候需要销毁
    工作的线程/存活的线程 < 20%,大部分都在歇着
    按照一定比例去杀死不干活的线程

3 线程池API

//创建线程池,池里最小3个线程,最大100个,队列最大100
threadpool_t * thp = threadpool_create(3,100,100);
    
//向线程池添加任务;thp是线程池,process是回调函数(模拟处理业务),(void*)&num[i]是给process传参
threadpool_add(thp, process, (void*) & num[i]);

posted on 2020-03-05 09:58  丁错儿  阅读(3)  评论(0编辑  收藏  举报

导航