|
@@ -14,28 +14,23 @@
|
|
|
private: \
|
|
private: \
|
|
|
DISABLE_COPY(Class) \
|
|
DISABLE_COPY(Class) \
|
|
|
static Class* s_pInstance; \
|
|
static Class* s_pInstance; \
|
|
|
|
|
+ static std::once_flag s_initFlag; \
|
|
|
static std::mutex s_mutex;
|
|
static std::mutex s_mutex;
|
|
|
|
|
|
|
|
#define SINGLETON_IMPL(Class) \
|
|
#define SINGLETON_IMPL(Class) \
|
|
|
Class* Class::s_pInstance = NULL; \
|
|
Class* Class::s_pInstance = NULL; \
|
|
|
|
|
+ std::once_flag Class::s_initFlag; \
|
|
|
std::mutex Class::s_mutex; \
|
|
std::mutex Class::s_mutex; \
|
|
|
Class* Class::instance() { \
|
|
Class* Class::instance() { \
|
|
|
- if (s_pInstance == NULL) { \
|
|
|
|
|
- s_mutex.lock(); \
|
|
|
|
|
- if (s_pInstance == NULL) { \
|
|
|
|
|
- s_pInstance = new Class; \
|
|
|
|
|
- } \
|
|
|
|
|
- s_mutex.unlock(); \
|
|
|
|
|
- } \
|
|
|
|
|
- return s_pInstance; \
|
|
|
|
|
|
|
+ std::call_once(s_initFlag, []() {s_pInstance = new Class;}); \
|
|
|
|
|
+ return s_pInstance; \
|
|
|
} \
|
|
} \
|
|
|
void Class::exitInstance() { \
|
|
void Class::exitInstance() { \
|
|
|
- s_mutex.lock(); \
|
|
|
|
|
- if (s_pInstance) { \
|
|
|
|
|
|
|
+ std::lock_guard<std::mutex> lock(s_mutex); \
|
|
|
|
|
+ if (s_pInstance) { \
|
|
|
delete s_pInstance; \
|
|
delete s_pInstance; \
|
|
|
- s_pInstance = NULL; \
|
|
|
|
|
- } \
|
|
|
|
|
- s_mutex.unlock(); \
|
|
|
|
|
|
|
+ s_pInstance = nullptr; \
|
|
|
|
|
+ } \
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
#endif // HV_SINGLETON_H_
|
|
#endif // HV_SINGLETON_H_
|