网站首页 > 博客文章 正文
最近项目上线,需要对系统的健康状况进行巡检,并将巡检报告输出到Excel表格中,本来打算用Java来做,但是……Java开发人员一来事情太多,每天都在不停的开发新的功能和生产新的Bug;二来面对C++开发应用不断被Java挤压的实际情况,也不得不给仅有的C++开发人员找点事情做,于是乎就决定使用C++来写定时任务。
先说下定时任务的重要性,定时任务允许开发人员在指定的时间间隔内重复、自动地执行某项任务,在数据处理、自动化以及准实时系统中占据着优势地位。极大的减少了生产系统中重复性的工作,一个功能完善的定时任务调度框架,通常由以下几个部分构成:
- 任务调度器:负责任务的管理和执行
- 任务统一接口:使用定时任务框架必须遵守的协议,这样也方便管理
- 定时器:就是高效的管理时间计划,准确的触发任务执行。
在说完上面的内容之后,下面再来看下怎么去实现一个定时任务调度框架。
1、任务统一接口
由一个纯虚类组成,每个任务可以继承该类,包含两个纯虚函数,分别是任务执行和任务状态判断。
class Task {
public:
virtual void execute() = 0;
virtual bool isReady() const = 0;
};
2、任务调度器
用来管理一组任务,任务到达指定的运行时间后就自动执行定时任务。这里用vector实现,也可以用队列进行管理。
class TaskScheduler {
private:
std::vector<std::unique_ptr<Task>> tasks;
public:
void addTask(std::unique_ptr<Task> task) {
tasks.push_back(std::move(task));
}
void runTasks() {
for (auto& task : tasks) {
if (task->isReady()) {
task->execute();
}
}
}
};
3、定时器
定时器就是对时间进行管理,以便每个任务都能准确的执行,这个模块不拘泥形式,可以单独的类实现,也可以在主函数中实现。
#include <chrono>
#include <thread>
void runScheduler(TaskScheduler& scheduler) {
while (true) {
scheduler.runTasks();
std::this_thread::sleep_for(std::chrono::seconds(1)); // 根据需要调整间隔
}
}
一个好的定时任务框架,除了能够承担正常的生产需求外,还需要具备以下三个特点:
- 可扩展性:能后灵活增加定时任务并进行管理
- 灵活性:满足各种生产需求
- 可靠性:让每个任务都能准确执行,并反馈任务执行状态
使用C++构建的定时任务框架,开发人员可以简化任务管理、提升应用效率并将关键流程进行自动化。无论是开发运维工具还是复杂系统,都可以对该框架进行扩展,从而满足生产各种需求。
猜你喜欢
- 2024-10-01 操作系统 : 按优先数调度算法实现处理器调度(C++)
- 2024-10-01 c++ 疑难杂症(13) allocator(c++ catch all exception)
- 2024-10-01 百度C++工程师的那些极限优化(内存篇)
- 2024-10-01 C++20 香不香?从四大新特性看起(c++20支持)
- 2024-10-01 用C++11打造智能观察者模式:详解实现步骤完整示例代码
- 2024-10-01 网络编程:手绘TCP状态机(tcp状态转换图详解)
- 2024-10-01 C++为什么不提倡使用单例模式?(c++为什么不用printf)
- 2024-10-01 智能系统机器人!C++实现三阶魔方自动求解程序源码
- 2024-10-01 ChaosBlade 发布对 C++ 应用混沌实验的支持
- 2024-10-01 C/C++编程笔记:C++智能指针及其类型的介绍!重点分析
你 发表评论:
欢迎- 07-08Google Cloud Platform 加入支持 Docker 的容器引擎
- 07-08日本KDDI与Google Cloud 签署合作备忘录,共探AI未来
- 07-08美国Infoblox与Google Cloud合作推出云原生网络和安全解决方案
- 07-08GoogleCloud为Spanner数据库引入HDD层,将冷存储成本降低80%
- 07-08谷歌推出Cloud Dataproc,缩短集群启动时间
- 07-08Infovista与Google Cloud携手推进射频网络规划革新
- 07-08比利时Odoo与Google Cloud建立增强合作,扩大全球影响力
- 07-08BT 和 Google Cloud 通过 Global Fabric 加速 AI 网络
- 最近发表
-
- Google Cloud Platform 加入支持 Docker 的容器引擎
- 日本KDDI与Google Cloud 签署合作备忘录,共探AI未来
- 美国Infoblox与Google Cloud合作推出云原生网络和安全解决方案
- GoogleCloud为Spanner数据库引入HDD层,将冷存储成本降低80%
- 谷歌推出Cloud Dataproc,缩短集群启动时间
- Infovista与Google Cloud携手推进射频网络规划革新
- 比利时Odoo与Google Cloud建立增强合作,扩大全球影响力
- BT 和 Google Cloud 通过 Global Fabric 加速 AI 网络
- NCSA和Google Cloud合作开发AI驱动的网络防御系统,加强泰国网络空间的安全性
- SAP将在沙特阿拉伯 Google Cloud 上推出BTP服务
- 标签列表
-
- ifneq (61)
- 字符串长度在线 (61)
- googlecloud (64)
- messagesource (56)
- promise.race (63)
- 2019cad序列号和密钥激活码 (62)
- window.performance (66)
- qt删除文件夹 (72)
- mysqlcaching_sha2_password (64)
- ubuntu升级gcc (58)
- nacos启动失败 (64)
- ssh-add (70)
- jwt漏洞 (58)
- macos14下载 (58)
- yarnnode (62)
- abstractqueuedsynchronizer (64)
- source~/.bashrc没有那个文件或目录 (65)
- springboot整合activiti工作流 (70)
- jmeter插件下载 (61)
- 抓包分析 (60)
- idea创建mavenweb项目 (65)
- vue回到顶部 (57)
- qcombobox样式表 (68)
- tomcatundertow (58)
- pastemac (61)
本文暂时没有评论,来添加一个吧(●'◡'●)