12.muduo学习笔记之base_ThreadPool.{h&cc}

1. 类说明

1. 功能

  • muduo的线程池类

2. 继承

  1. noncopyable

2. 成员变量说明

  1. mutex_
  2. notEmpty_/notFull_
    • 条件变量
  3. name_
    • 线程池名字
  4. threadInitCallback_
    • Task类型,是void()的std::function,在类内定义的
  5. threads_
    • 线程指针的数组(vector),指向线程池中的线程
  6. queue_
    • deque类型的Task队列
  7. maxQueueSize_
    • 最大值
  8. running_
    • bool类型,看是否有线程在运行

3. 成员函数说明

1. 普通

  1. 构造函数
    • 初始化变量,要传入name,不传的话有默认的名字
  2. 析构函数
    • 如果running_为true,调用stop()
  3. setMaxQueueSize(int)
    • 如名
  4. setThreadInitCallback(const Task&)
    • 设置回调函数
  5. start(int)
    • 设置线程的数量,并设置线程的状态为running,并且通过 threads_.reserve(numThreads)设置线程池中线程的数量,同时设置线程的回调函数
    • 使用了emplace_back,和push_back功能类似,但是可以避免额外的复制和移动操作.emplace_back的参数是右值
    • 所有线程启动,以runInThread()作为线程函数
  6. stop()
    • 将线程池的状态修改为停止,同时等待所有的线程结束
  7. name()
    • 返回name_
  8. queueSize()
    • 返回任务队列的大小,即看有多少个任务
  9. run(Task)
    • 如果线程队列为空,就直接运行,否则的话把任务加到任务队列

2. 私有

  1. isFull()
    • 看任务队列是否已经到达最大值
  2. runInThread()
    • 若threadInitCallback_存在,先调用这个函数
    • 线程循环从task中取出任务执行
  3. take()
    • 如果任务队列不为空,从队首取出任务,否则一直等待
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值