#include <balb_performancemonitor.h>
|
enum | Measure {
e_CPU_TIME
, e_CPU_TIME_USER
, e_CPU_TIME_SYSTEM
, e_CPU_UTIL
,
e_CPU_UTIL_USER
, e_CPU_UTIL_SYSTEM
, e_RESIDENT_SIZE
, e_NUM_THREADS
,
e_NUM_PAGEFAULTS
, e_VIRTUAL_SIZE
, e_NUM_MEASURES
, BAEA_CPU_TIME = e_CPU_TIME
,
BAEA_CPU_TIME_USER = e_CPU_TIME_USER
, BAEA_CPU_TIME_SYSTEM = e_CPU_TIME_SYSTEM
, BAEA_CPU_UTIL = e_CPU_UTIL
, BAEA_CPU_UTIL_USER = e_CPU_UTIL_USER
,
BAEA_CPU_UTIL_SYSTEM = e_CPU_UTIL_SYSTEM
, BAEA_RESIDENT_SIZE = e_RESIDENT_SIZE
, BAEA_NUM_THREADS = e_NUM_THREADS
, BAEA_NUM_PAGEFAULTS = e_NUM_PAGEFAULTS
,
BAEA_VIRTUAL_SIZE = e_VIRTUAL_SIZE
, BAEA_NUM_MEASURES = e_NUM_MEASURES
, CPU_TIME = e_CPU_TIME
, CPU_TIME_USER = e_CPU_TIME_USER
,
CPU_TIME_SYSTEM = e_CPU_TIME_SYSTEM
, CPU_UTIL = e_CPU_UTIL
, CPU_UTIL_USER = e_CPU_UTIL_USER
, CPU_UTIL_SYSTEM = e_CPU_UTIL_SYSTEM
,
RESIDENT_SIZE = e_RESIDENT_SIZE
, NUM_THREADS = e_NUM_THREADS
, NUM_PAGEFAULTS = e_NUM_PAGEFAULTS
, VIRTUAL_SIZE = e_VIRTUAL_SIZE
,
NUM_MEASURES = e_NUM_MEASURES
} |
|
Provides a mechanism to collect performance statistics for an arbitrary number of processes running on the local machine.
See balb_performancemonitor
◆ Measure
Enumerator |
---|
e_CPU_TIME | |
e_CPU_TIME_USER | |
e_CPU_TIME_SYSTEM | |
e_CPU_UTIL | |
e_CPU_UTIL_USER | |
e_CPU_UTIL_SYSTEM | |
e_RESIDENT_SIZE | |
e_NUM_THREADS | |
e_NUM_PAGEFAULTS | |
e_VIRTUAL_SIZE | |
e_NUM_MEASURES | |
BAEA_CPU_TIME | |
BAEA_CPU_TIME_USER | |
BAEA_CPU_TIME_SYSTEM | |
BAEA_CPU_UTIL | |
BAEA_CPU_UTIL_USER | |
BAEA_CPU_UTIL_SYSTEM | |
BAEA_RESIDENT_SIZE | |
BAEA_NUM_THREADS | |
BAEA_NUM_PAGEFAULTS | |
BAEA_VIRTUAL_SIZE | |
BAEA_NUM_MEASURES | |
CPU_TIME | |
CPU_TIME_USER | |
CPU_TIME_SYSTEM | |
CPU_UTIL | |
CPU_UTIL_USER | |
CPU_UTIL_SYSTEM | |
RESIDENT_SIZE | |
NUM_THREADS | |
NUM_PAGEFAULTS | |
VIRTUAL_SIZE | |
NUM_MEASURES | |
◆ PerformanceMonitor() [1/2]
balb::PerformanceMonitor::PerformanceMonitor |
( |
bslma::Allocator * |
basicAllocator = 0 | ) |
|
|
explicit |
Create an instance of this class to collect performance statistics on demand (via the collect
method). Optionally specify a basicAllocator
used to supply memory. If basicAllocator
is 0, the currently installed default allocator is used.
◆ PerformanceMonitor() [2/2]
Create an instance of this class that uses the specified scheduler
to automatically collect performance statistics every specified interval
(specified in seconds). Optionally specify a basicAllocator
used to supply memory. If basicAllocator
is 0, the currently installed default allocator is used. Note that a non-positive interval
value indicates that performance statistics should not be automatically collected–in this case the user is responsible for manually calling the collect
function.
◆ ~PerformanceMonitor()
balb::PerformanceMonitor::~PerformanceMonitor |
( |
| ) |
|
◆ begin()
Return an iterator positioned at the first set of collected performance statistics.
◆ BSLMF_NESTED_TRAIT_DECLARATION()
◆ collect()
void balb::PerformanceMonitor::collect |
( |
| ) |
|
◆ end()
Return an iterator that represents the end of the sequence of sets of collected performance statistics.
◆ find()
Return the iterator pointing to the set of collected performance statistics for the specified pid
if pid
has been registered with this performance monitor through the registerPid
function, otherwise return end()
.
◆ numRegisteredPids()
int balb::PerformanceMonitor::numRegisteredPids |
( |
| ) |
const |
|
inline |
◆ registerPid()
int balb::PerformanceMonitor::registerPid |
( |
int |
pid, |
|
|
const bsl::string & |
description |
|
) |
| |
Register the specified process pid
having the specified user-defined description
with this performance monitor. After registration, performance statistics will be collected for the pid
upon invocation of the collect
function. Note that a pid
value of zero is interpreted as the pid
of the current process. Return 0 on success or a non-zero value otherwise.
◆ resetStatistics()
void balb::PerformanceMonitor::resetStatistics |
( |
| ) |
|
Reset the collected min, max, and average values collected for each measure for each monitored process.
◆ setCollectionInterval()
void balb::PerformanceMonitor::setCollectionInterval |
( |
double |
interval | ) |
|
Set the specified time interval
, in seconds, after which statistics for each registered pid are automatically collected. The behavior is undefined unless a scheduler was supplied at the construction of this performance monitor. Note that a non-positive interval
value indicates that performance statistics should not be automatically collected–in this case the user is responsible for manually calling the collect
function.
◆ unregisterPid()
int balb::PerformanceMonitor::unregisterPid |
( |
int |
pid | ) |
|
Unregister the specified process pid
from the performance monitor. After unregistration, to statistics for the pid
will be no longer be available unless the pid
is re-registered with the performance monitor through calling registerPid
. Note that a pid
value of zero is interpreted as the pid
of the current process. Return 0 on success or a non-zero value otherwise.
◆ ConstIterator
◆ Statistics
The documentation for this class was generated from the following file: