获取标准::未来<T>::wait_for的经过时间

Get elapsed time of std::future<T>::wait_for

本文关键字:for 时间 wait 经过 标准 未来 lt 获取 gt      更新时间:2023-10-16

如果没有发生超时,有没有一种简单的方法来获取std::future<T>::wait_for期间经过的时间?我想实现这样的事情:

std::future<void> futureRet = std::async(std::launch::async, &Someone::doSomething, this);
futureRet.wait_for(std::chrono::seconds(30));
cout << "doSomething returned after <" << futureRet.getElapsedTime() << "> seconds.";

是否有一种"getElapsedTime(("函数,或者我必须自己计算经过的时间?

有一个简单的方法使用 <chrono>

auto start = std::chrono::steady_clock::now();
std::future<void> futureRet = std::async(std::launch::async, &Someone::doSomething, this);
futureRet.wait_for(std::chrono::seconds(30));
auto end = std::chrono::steady_clock::now();
std::chrono::duration<double> elapsed_seconds = end - start;    
cout << "doSomething returned after <" << elapsed_seconds.count() << "> seconds.";