fix crash for static ThreadPool
This commit is contained in:
parent
85852ee2e9
commit
0a2c5e3ca7
@ -14,23 +14,30 @@ DecrementFuturesUsage()
|
|||||||
|
|
||||||
}// namespace future_detail
|
}// namespace future_detail
|
||||||
|
|
||||||
static ThreadPool g_default_thread_pool;
|
static std::atomic<TaskQueueBase *> g_default_scheduler{nullptr};
|
||||||
TaskQueueBase *g_default_scheduler = &g_default_thread_pool;
|
// static ThreadPool default_thread_pool;
|
||||||
|
static std::unique_ptr<Thread> g_default_thread;
|
||||||
|
|
||||||
void
|
void
|
||||||
SetDefaultScheduler(TaskQueueBase *scheduler) noexcept
|
SetDefaultScheduler(TaskQueueBase *scheduler) noexcept
|
||||||
{
|
{
|
||||||
if (scheduler == nullptr) {
|
SLED_ASSERT(scheduler, "scheduler is nullptr");
|
||||||
g_default_scheduler = &g_default_thread_pool;
|
g_default_scheduler.store(scheduler, std::memory_order_release);
|
||||||
} else {
|
|
||||||
g_default_scheduler = scheduler;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
TaskQueueBase *
|
TaskQueueBase *
|
||||||
GetDefaultScheduler() noexcept
|
GetDefaultScheduler() noexcept
|
||||||
{
|
{
|
||||||
return g_default_scheduler;
|
static std::once_flag flag;
|
||||||
|
std::call_once(flag, [&] {
|
||||||
|
g_default_thread = sled::Thread::Create();
|
||||||
|
g_default_thread->Start();
|
||||||
|
TaskQueueBase *null_scheduler = nullptr;
|
||||||
|
while (g_default_scheduler.load() == nullptr) {
|
||||||
|
g_default_scheduler.compare_exchange_weak(null_scheduler, g_default_thread.get());
|
||||||
|
}
|
||||||
|
});
|
||||||
|
return g_default_scheduler.load(std::memory_order_acquire);
|
||||||
}
|
}
|
||||||
|
|
||||||
}// namespace sled
|
}// namespace sled
|
||||||
|
Loading…
x
Reference in New Issue
Block a user