📄 timer.c
字号:
#include "Timer.h"/* * The virtual time of day and the real time of day are calculated and * stored for future use. The future use consists of subtracting these * values from similar values obtained at a later time to allow the user * to get the amount of time used by the algorithm. */Timer::Timer(void) { getrusage( RUSAGE_SELF, &res ); virtual_time = (double) res.ru_utime.tv_sec + (double) res.ru_stime.tv_sec + (double) res.ru_utime.tv_usec * 1.0E-6 + (double) res.ru_stime.tv_usec * 1.0E-6; gettimeofday( &tp, 0 ); real_time = (double) tp.tv_sec + (double) tp.tv_usec * 1.0E-6;}voidTimer::resetTime() { getrusage( RUSAGE_SELF, &res ); virtual_time = (double) res.ru_utime.tv_sec + (double) res.ru_stime.tv_sec + (double) res.ru_utime.tv_usec * 1.0E-6 + (double) res.ru_stime.tv_usec * 1.0E-6; gettimeofday( &tp, 0 ); real_time = (double) tp.tv_sec + (double) tp.tv_usec * 1.0E-6;}/* * Stop the stopwatch and return the time used in seconds (either * REAL or VIRTUAL time, depending on ``type''). */double Timer::elapsedTime(const TYPE& type) { if (type == REAL) { gettimeofday( &tp, 0 ); return( (double) tp.tv_sec + (double) tp.tv_usec * 1.0E-6 - real_time ); } else { getrusage( RUSAGE_SELF, &res ); return( (double) res.ru_utime.tv_sec + (double) res.ru_stime.tv_sec + (double) res.ru_utime.tv_usec * 1.0E-6 + (double) res.ru_stime.tv_usec * 1.0E-6 - virtual_time ); }}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -