mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-04-03 06:13:08 +02:00
gmain: use atomic operation instead of GMutex to access g_main_context_default()
I think it is wasteful to use a mutex every time the default main context is accessed. Especially, as the default main context is used all the time.
This commit is contained in:
parent
038ec3de31
commit
39dd2be538
26
glib/gmain.c
26
glib/gmain.c
@ -439,9 +439,6 @@ static void block_source (GSource *source);
|
|||||||
|
|
||||||
static GMainContext *glib_worker_context;
|
static GMainContext *glib_worker_context;
|
||||||
|
|
||||||
G_LOCK_DEFINE_STATIC (main_loop);
|
|
||||||
static GMainContext *default_main_context;
|
|
||||||
|
|
||||||
#ifndef G_OS_WIN32
|
#ifndef G_OS_WIN32
|
||||||
|
|
||||||
|
|
||||||
@ -667,34 +664,35 @@ g_main_context_new (void)
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* g_main_context_default:
|
* g_main_context_default:
|
||||||
*
|
*
|
||||||
* Returns the global default main context. This is the main context
|
* Returns the global default main context. This is the main context
|
||||||
* used for main loop functions when a main loop is not explicitly
|
* used for main loop functions when a main loop is not explicitly
|
||||||
* specified, and corresponds to the "main" main loop. See also
|
* specified, and corresponds to the "main" main loop. See also
|
||||||
* g_main_context_get_thread_default().
|
* g_main_context_get_thread_default().
|
||||||
*
|
*
|
||||||
* Returns: (transfer none): the global default main context.
|
* Returns: (transfer none): the global default main context.
|
||||||
**/
|
**/
|
||||||
GMainContext *
|
GMainContext *
|
||||||
g_main_context_default (void)
|
g_main_context_default (void)
|
||||||
{
|
{
|
||||||
/* Slow, but safe */
|
static GMainContext *default_main_context;
|
||||||
|
|
||||||
G_LOCK (main_loop);
|
|
||||||
|
|
||||||
if (!default_main_context)
|
if (g_once_init_enter (&default_main_context))
|
||||||
{
|
{
|
||||||
default_main_context = g_main_context_new ();
|
GMainContext *context;
|
||||||
|
|
||||||
TRACE (GLIB_MAIN_CONTEXT_DEFAULT (default_main_context));
|
context = g_main_context_new ();
|
||||||
|
|
||||||
|
TRACE (GLIB_MAIN_CONTEXT_DEFAULT (context));
|
||||||
|
|
||||||
#ifdef G_MAIN_POLL_DEBUG
|
#ifdef G_MAIN_POLL_DEBUG
|
||||||
if (_g_main_poll_debug)
|
if (_g_main_poll_debug)
|
||||||
g_print ("default context=%p\n", default_main_context);
|
g_print ("default context=%p\n", context);
|
||||||
#endif
|
#endif
|
||||||
}
|
|
||||||
|
|
||||||
G_UNLOCK (main_loop);
|
g_once_init_leave ((gsize *) &default_main_context, (gsize) context);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
return default_main_context;
|
return default_main_context;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user