您可以使用std::chrono测量准确的时间
#include <chrono>
auto timeStart = std::chrono::high_resolution_clock::now();
// do something... wait for result...
auto timeEnd = std::chrono::high_resolution_clock::now();
long long duration = std::chrono::duration_cast<std::chrono::microseconds>(timeEnd - timeStart).count();
Run Code Online (Sandbox Code Playgroud)
替换microseconds为nanoseconds, milliseconds,seconds以获得不同单位的持续时间。
您也可以使用std::clock,尽管它可能提供不太准确的测量:
#include <ctime>
std::clock_t timeStart = std::clock();
// do something... wait for result...
std::clock_t timeEnd = std::clock();
double durationMs = 1000.0 * (timeEnd-timeStart) / CLOCKS_PER_SEC;
Run Code Online (Sandbox Code Playgroud)