huangcm
2025-07-01 676035278781360996553c427a12bf358249ebf7
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
#ifndef BENCHMARK_TIMERS_H
#define BENCHMARK_TIMERS_H
 
#include <chrono>
#include <string>
 
namespace benchmark {
 
// Return the CPU usage of the current process
double ProcessCPUUsage();
 
// Return the CPU usage of the children of the current process
double ChildrenCPUUsage();
 
// Return the CPU usage of the current thread
double ThreadCPUUsage();
 
#if defined(HAVE_STEADY_CLOCK)
template <bool HighResIsSteady = std::chrono::high_resolution_clock::is_steady>
struct ChooseSteadyClock {
  typedef std::chrono::high_resolution_clock type;
};
 
template <>
struct ChooseSteadyClock<false> {
  typedef std::chrono::steady_clock type;
};
#endif
 
struct ChooseClockType {
#if defined(HAVE_STEADY_CLOCK)
  typedef ChooseSteadyClock<>::type type;
#else
  typedef std::chrono::high_resolution_clock type;
#endif
};
 
inline double ChronoClockNow() {
  typedef ChooseClockType::type ClockType;
  using FpSeconds = std::chrono::duration<double, std::chrono::seconds::period>;
  return FpSeconds(ClockType::now().time_since_epoch()).count();
}
 
std::string LocalDateTimeString();
 
}  // end namespace benchmark
 
#endif  // BENCHMARK_TIMERS_H