c++异构计算获取计算进度

异步运行任务,并定期检查任务是否已完成。如果没有,您希望打印出任务的进度。但是,您提供的代码存在一些问题:

1。"TaskRun"类未在您提供的代码段中定义。请确保其定义正确,并且"run"方法是"TaskRun"的成员函数。

2."taskManage"对象未在代码段中定义。请确保它已正确初始化,并且可以在代码范围内访问。

3."relSimVec"对象未在代码段中定义。请确保它已正确初始化,并且可以在代码范围内访问。

4.代码段中未定义"totSimNum"变量。请确保它已正确初始化,并且可以在代码范围内访问。

假设"TaskRun"类和"taskManage"对象定义正确,下面是代码的更正版本:

复制代码
#include <iostream>
#include <future>
#include <chrono>

// Assuming TaskRun and TaskManage are defined as follows:
class TaskRun {
public:
    TaskRun(MPS_Alg mps_alg, TaskManage* taskManage, std::vector<RelSim>* relSimVec)
        : mps_alg(mps_alg), taskManage(taskManage), relSimVec(relSimVec) {}

    void run() {
        // Perform the task here
    }

private:
    MPS_Alg mps_alg;
    TaskManage* taskManage;
    std::vector<RelSim>* relSimVec;
};

class TaskManage {
public:
    int simCellNum;
    // Other members and methods...
};

// Assuming MPS_Alg and RelSim are defined elsewhere

int main() {
    // Assuming mps_alg, relSimVec, and totSimNum are properly defined
    MPS_Alg mps_alg;
    std::vector<RelSim> relSimVec;
    int totSimNum = 100; // Example total number of simulations

    // Create TaskManage and TaskRun instances
    TaskManage taskManage;
    TaskRun taskRun(mps_alg, &taskManage, &relSimVec);

    // Launch task and get result future
    auto rf = std::async(std::launch::async, &TaskRun::run, &taskRun);

    // Check if the task has finished every 5 seconds
    while (rf.wait_for(std::chrono::seconds(5)) == std::future_status::timeout) {
        std::cout << taskManage.simCellNum << "/" << totSimNum << std::endl;
    }

    // Ensure the task is finished
    rf.get();

    return 0;
}

请将占位符替换为"MPS_Alg"、"RelSim"和"TaskManage"的实际定义。此外,请确保"TaskRun"的"run"方法执行实际任务,并相应地更新"taskManage.simCellNum"。

相关推荐
焦耳加热25 分钟前
阿德莱德大学Nat. Commun.:盐模板策略实现废弃塑料到单原子催化剂的高值转化,推动环境与能源催化应用
人工智能·算法·机器学习·能源·材料工程
wan5555cn33 分钟前
多张图片生成视频模型技术深度解析
人工智能·笔记·深度学习·算法·音视频
u6061 小时前
常用排序算法核心知识点梳理
算法·排序
蒋星熠3 小时前
Flutter跨平台工程实践与原理透视:从渲染引擎到高质产物
开发语言·python·算法·flutter·设计模式·性能优化·硬件工程
小欣加油4 小时前
leetcode 面试题01.02判定是否互为字符重排
数据结构·c++·算法·leetcode·职场和发展
3Cloudream4 小时前
LeetCode 003. 无重复字符的最长子串 - 滑动窗口与哈希表详解
算法·leetcode·字符串·双指针·滑动窗口·哈希表·中等
王璐WL4 小时前
【c++】c++第一课:命名空间
数据结构·c++·算法
空白到白4 小时前
机器学习-聚类
人工智能·算法·机器学习·聚类
索迪迈科技5 小时前
java后端工程师进修ing(研一版 || day40)
java·开发语言·学习·算法
zzzsde5 小时前
【数据结构】队列
数据结构·算法