Commit a0910792 authored by gabime's avatar gabime

Fix Visual Studio poor std::this_thread::get_id() performance by using…

Fix Visual Studio poor  std::this_thread::get_id() performance by using GetCurrentThreadId() (and pthread_self() under linux)
parent 67e0957e
...@@ -60,7 +60,7 @@ class async_log_helper ...@@ -60,7 +60,7 @@ class async_log_helper
level::level_enum level; level::level_enum level;
log_clock::time_point time; log_clock::time_point time;
std::string txt; std::string txt;
std::thread::id thread_id; uint64_t thread_id;
async_msg() = default; async_msg() = default;
~async_msg() = default; ~async_msg() = default;
......
...@@ -64,7 +64,9 @@ public: ...@@ -64,7 +64,9 @@ public:
{ {
_log_msg.logger_name = _callback_logger->name(); _log_msg.logger_name = _callback_logger->name();
_log_msg.time = os::now(); _log_msg.time = os::now();
_log_msg.thread_id = std::this_thread::get_id(); _log_msg.thread_id = os::thread_id();
_callback_logger->_log_msg(_log_msg); _callback_logger->_log_msg(_log_msg);
} }
} }
......
...@@ -92,7 +92,7 @@ struct log_msg ...@@ -92,7 +92,7 @@ struct log_msg
std::string logger_name; std::string logger_name;
level::level_enum level; level::level_enum level;
log_clock::time_point time; log_clock::time_point time;
std::thread::id thread_id; uint64_t thread_id;
fmt::MemoryWriter raw; fmt::MemoryWriter raw;
fmt::MemoryWriter formatted; fmt::MemoryWriter formatted;
}; };
......
...@@ -32,6 +32,8 @@ ...@@ -32,6 +32,8 @@
# define WIN32_LEAN_AND_MEAN # define WIN32_LEAN_AND_MEAN
# endif # endif
# include <Windows.h> # include <Windows.h>
#else
#include <pthread.h>
#endif #endif
#include "../common.h" #include "../common.h"
...@@ -167,6 +169,17 @@ inline int utc_minutes_offset(const std::tm& tm = details::os::localtime()) ...@@ -167,6 +169,17 @@ inline int utc_minutes_offset(const std::tm& tm = details::os::localtime())
} }
inline uint64_t thread_id()
{
#ifdef _WIN32
return ::GetCurrentThreadId();
#else
return (uint64_t) pthread_self();
#endif
}
} //os } //os
} //details } //details
} //spdlog } //spdlog
......
...@@ -354,7 +354,7 @@ class t_formatter :public flag_formatter ...@@ -354,7 +354,7 @@ class t_formatter :public flag_formatter
{ {
void format(details::log_msg& msg, const std::tm&) override void format(details::log_msg& msg, const std::tm&) override
{ {
msg.formatted << std::hash<std::thread::id>()(msg.thread_id); msg.formatted << msg.thread_id;
} }
}; };
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment