获取 std::future<T>::wait_for 的经过时间
Get elapsed time of std::future<T>::wait_for
如果没有发生超时,是否有一种简单的方法可以获取 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.";
如果没有发生超时,是否有一种简单的方法可以获取 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.";