blob: 87ea0c59f1650b8d716415a2d31a59d31d7f77fb (
plain) (
blame)
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
49
50
51
52
53
|
#pragma once
#include <util/system/atomic.h>
/**
* Simple thread-safe per-class counter that can be used to make sure you don't
* have any leaks in your code, or for statistical purposes.
*
* Example usage:
* \code
* class TMyClass: public TObjectCounter<TMyClass> {
* // ...
* };
*
* // In your code:
* Cerr << "TMyClass instances in use: " << TMyClass::ObjectCount() << Endl;
* \endcode
*/
template <class T>
class TObjectCounter {
public:
inline TObjectCounter() noexcept {
AtomicIncrement(Count_);
}
inline TObjectCounter(const TObjectCounter& /*item*/) noexcept {
AtomicIncrement(Count_);
}
inline ~TObjectCounter() {
AtomicDecrement(Count_);
}
static inline long ObjectCount() noexcept {
return AtomicGet(Count_);
}
/**
* Resets object count. Mainly for tests, as you don't want to do this in
* your code and then end up with negative counts.
*
* \returns Current object count.
*/
static inline long ResetObjectCount() noexcept {
return AtomicSwap(&Count_, 0);
}
private:
static TAtomic Count_;
};
template <class T>
TAtomic TObjectCounter<T>::Count_ = 0;
|