代码拉取完成,页面将自动刷新
同步操作将从 niukey/threadpool 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
#pragma once
#include "stddef.hpp"
#include "task_t.hpp"
#include "thread_t.h"
#include "task_queue_t.h"
class threadpool_t
{
public:
typedef std::lock_guard<std::mutex> lock_guard_t;
threadpool_t(void);
~threadpool_t(void);
void add_task(task_t &task_);
void init(uint32_t max_thread_num, uint32_t idle_timeout);
void destroy();
private:
void init_thread(uint32_t max_thread_num, uint32_t idle_timeout);
void create_a_new_thread();
bool pull_task(task_ptr_t &task_);
void thread_exit_pro(uint32_t tid_);
uint32_t next_tid();
typedef std::list<thread_ptr_t> thread_list_t;
thread_t::pull_task_fun_t pull_task_fun;
thread_t::exit_fun_t thread_exit_fun;
thread_list_t alive_thread_list;
thread_list_t dead_thread_list;
task_queue_t task_queue;
std::mutex thread_list_mutex;
uint32_t mini_thread_count;
uint32_t max_thread_num;
uint32_t idle_timeout;
};
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。