Home >Backend Development >C++ >How Can I Measure the Execution Time of a C Function?
In C programming, measuring the execution time of a function can be accomplished effectively. The Boost.Chrono library offers the process_user_cpu_clock() function, which captures the user-CPU time utilized by the current process. This function, along with alternative methods, provides valuable insights for performance optimization.
Using process_user_cpu_clock() in Boost.Chrono is straightforward. Here's an example:
#include <boost/chrono.hpp> #include <iostream> void long_operation() { // Simulating a long operation boost::chrono::process_user_cpu_clock timer; while (timer.seconds() < 1) { } } int main() { boost::chrono::process_user_cpu_clock start; long_operation(); boost::chrono::process_user_cpu_clock stop; std::cout << "Execution time: " << (stop - start).seconds() << " seconds" << std::endl; return 0; }
In C 11, std::chrono::high_resolution_clock() from the Both methods offer reliable measurements. std::chrono::high_resolution_clock() is the preferred choice for measuring specific function durations. Boost.Chrono provides additional features, such as thread timing and context timers. By utilizing these methods, developers can effectively determine the execution time of functions, leading to well-optimized and efficient C programs. The above is the detailed content of How Can I Measure the Execution Time of a C Function?. For more information, please follow other related articles on the PHP Chinese website!#include <chrono>
#include <iostream>
void long_operation() {
// Simulating a long operation
std::chrono::high_resolution_clock timer;
std::this_thread::sleep_for(std::chrono::seconds(1));
}
int main() {
std::chrono::high_resolution_clock::time_point start = std::chrono::high_resolution_clock::now();
long_operation();
std::chrono::high_resolution_clock::time_point stop = std::chrono::high_resolution_clock::now();
std::cout << "Execution time: " << std::chrono::duration_cast<std::chrono::milliseconds>(stop - start).count() << " milliseconds" << std::endl;
return 0;
}
Performance Comparison
Conclusion