当前位置: 首页 > news >正文

建设一个网站花多少钱/如何在百度上发表文章

建设一个网站花多少钱,如何在百度上发表文章,什么浏览器可以看违规网站,做鸭网站实现一个服务器端线程池需要处理多个客户端请求&#xff0c;同时提高资源利用率和响应速度。 在main函数中&#xff0c;创建一个线程池并提交多个任务。每个任务在不同的线程中执行&#xff0c;演示了线程池的并发处理能力 #include <iostream> #include <vector>…

实现一个服务器端线程池需要处理多个客户端请求,同时提高资源利用率和响应速度。

  • main函数中,创建一个线程池并提交多个任务。
  • 每个任务在不同的线程中执行,演示了线程池的并发处理能力
#include <iostream>
#include <vector>
#include <thread>
#include <queue>
#include <mutex>
#include <condition_variable>
#include <functional>
#include <atomic>// 线程池类定义
class ThreadPool {
public:// 构造函数,接受线程数量作为参数ThreadPool(size_t numThreads);// 析构函数~ThreadPool();// 向任务队列中添加任务void enqueueTask(std::function<void()> task);private:// 工作线程的集合std::vector<std::thread> workers;// 任务队列std::queue<std::function<void()>> tasks;// 互斥锁保护任务队列std::mutex queueMutex;// 条件变量用于线程同步std::condition_variable condition;// 原子布尔值,用于指示线程池是否停止std::atomic<bool> stop;// 每个线程执行的函数void workerThread();
};// 线程池构造函数
ThreadPool::ThreadPool(size_t numThreads) : stop(false) {// 创建指定数量的线程,并将它们添加到工作线程集合中for (size_t i = 0; i < numThreads; ++i) {workers.emplace_back([this] { this->workerThread(); });}
}// 线程池析构函数
ThreadPool::~ThreadPool() {// 设置停止标志为truestop = true;// 通知所有等待的线程condition.notify_all();// 等待所有线程完成工作for (std::thread &worker : workers) {if (worker.joinable()) {worker.join();}}
}// 将任务添加到任务队列中
void ThreadPool::enqueueTask(std::function<void()> task) {{// 加锁以保护任务队列std::unique_lock<std::mutex> lock(queueMutex);// 将任务添加到队列中tasks.push(task);}// 通知一个等待的线程condition.notify_one();
}// 每个线程执行的函数,从任务队列中提取任务并执行
void ThreadPool::workerThread() {while (!stop) {std::function<void()> task;{// 加锁以保护任务队列std::unique_lock<std::mutex> lock(queueMutex);// 等待直到有任务或停止标志被设置condition.wait(lock, [this] { return stop || !tasks.empty(); });// 如果停止标志被设置且任务队列为空,则退出if (stop && tasks.empty()) {return;}// 从任务队列中取出一个任务task = std::move(tasks.front());tasks.pop();}// 执行任务task();}
}// 主函数,演示线程池的使用
int main() {// 创建一个线程池,包含4个线程ThreadPool pool(4);// 提交8个任务到线程池for (int i = 0; i < 8; ++i) {pool.enqueueTask([i] {std::cout << "Processing task " << i << " in thread " << std::this_thread::get_id() << std::endl;});}// 等待一段时间以确保所有任务完成std::this_thread::sleep_for(std::chrono::seconds(2));return 0;
}
  1. ThreadPool类:表示线程池,包含线程向量、任务队列、互斥锁、条件变量和停止标志。
  2. 构造函数:初始化线程池,创建指定数量的线程,并将每个线程指向workerThread函数。
  3. 析构函数:设置停止标志,通知所有线程并等待它们完成。
  4. enqueueTask方法:将任务添加到任务队列中,并通知一个等待线程。
  5. workerThread方法:线程工作函数,从任务队列中提取任务并执行。
http://www.whsansanxincailiao.cn/news/31973682.html

相关文章:

  • 升腾d9116 做网站/创建网站需要什么条件
  • 淘客导航网站开发/竞价托管哪家便宜
  • 做产品批发的网站有哪些/在线seo外链工具
  • 网站上传独立服务器/刷粉网站推广便宜
  • 网站定位策划/百度小说搜索风云排行榜
  • web开发网站建设方案书/百度站长工具官网
  • 购买已备案网站做非法/nba录像回放
  • 爬虫做网站相关教程/泰安优化关键词排名哪家合适
  • 地方网站做外卖/百度一下首页百度一下知道
  • 做我网站/百度指数的需求指数
  • 阿里巴巴国际站网站做销售方案/百度快速收录接口
  • 淮北网站开发/谷歌seo关键词优化
  • 泰安新浪乐居房产网/seo待遇
  • 上海做网站的公司电话/小说百度搜索风云榜
  • 怎么用网站的二级目录做排名/seo网站快速排名外包
  • 礼品公司怎么做网站/优化大师是干什么的
  • 如何看网站排名/网络推广
  • wordpress 加音乐/seo标题生成器
  • 济南企业做网站/条友网
  • 调查问卷wordpress/广西壮族自治区在线seo关键词排名优化
  • 微信公众号怎么做微网站吗/百度热线人工服务电话
  • 做网站的数据库/优化网站怎么做
  • 搜索引擎优化指南/seo咨询河北
  • 网站打开速度慢跟什么有关系/百度首页百度
  • 信息网站设计方案/百度我的订单
  • 科技创新论文800字/深圳网站优化
  • 大企业网站建设/好用的种子搜索引擎
  • 沧州各种网站/写手接单平台
  • 铁岭网站制作/小程序开发收费价目表
  • 白沟网站建设/seo如何去做优化