C++ 中的 then
函数通常与并发编程和异步任务处理相关
- 异步任务链:当一个异步任务完成后,执行另一个依赖于第一个任务结果的异步任务。
std::futuretask1 = std::async([]() { return 42; }); std::future task2 = task1.then([](std::future f) { int result = f.get(); // 获取 task1 的结果 return result * 2; });
- 并行任务组合:将多个独立的异步任务组合为一个新的异步任务,当所有子任务都完成时,新任务才会完成。
std::futuretaskA = std::async([]() { return 42; }); std::future taskB = std::async([]() { return 100; }); std::future combinedTask = taskA.then([&](std::future f) { int resultA = f.get(); return taskB.then([resultA](std::future g) { int resultB = g.get(); return resultA + resultB; }); });
- 错误处理:使用
then
函数处理异步任务中可能发生的异常。
std::futurefallibleTask = std::async([]() { if (/* some condition */) { throw std::runtime_error("An error occurred"); } return 42; }); std::future errorHandledTask = fallibleTask.then([](std::future f) { try { int result = f.get(); // 获取原始任务的结果,如果有异常,将在这里抛出 } catch (const std::exception& e) { // 处理异常 std::cerr << "Error: " << e.what()<< std::endl; } });
- 任务优先级调度:基于任务的优先级来安排任务执行顺序。
struct Task { std::functionwork; int priority; }; std::priority_queue , std::greater > taskQueue; // 添加任务到队列 taskQueue.push({[]() { /* low priority work */ }, 1}); taskQueue.push({[]() { /* high priority work */ }, 0}); // 执行任务 while (!taskQueue.empty()) { Task task = taskQueue.top(); taskQueue.pop(); task.work(); }
这些示例展示了 C++ 中 then
函数在并发编程中的一些应用场景。实际上,then
函数提供了一种简洁、表达力强的方式来处理异步任务之间的依赖关系,以及任务的组合、错误处理和优先级调度等问题。