Cleanup thread documentation

This commit is contained in:
Ryan Lortie 2011-10-06 12:01:53 -04:00
parent 49b93a0bba
commit 94b7d2ee6c
7 changed files with 115 additions and 152 deletions

View File

@ -24,10 +24,13 @@ CFILE_GLOB=$(top_srcdir)/glib/*.c $(top_srcdir)/gmodule/*.c
# Ignore some private headers # Ignore some private headers
IGNORE_HFILES = \ IGNORE_HFILES = \
gallocator.h \
gdatasetprivate.h \ gdatasetprivate.h \
glibintl.h \ glibintl.h \
gbsearcharray.h \ gbsearcharray.h \
glib-private.h \
gmoduleconf.h \ gmoduleconf.h \
gthreadprivate.h \
gunibreak.h \ gunibreak.h \
gunicomp.h \ gunicomp.h \
gunidecomp.h \ gunidecomp.h \

View File

@ -83,7 +83,6 @@ synchronize their operation.
<xi:include href="xml/hooks.xml" /> <xi:include href="xml/hooks.xml" />
<xi:include href="xml/misc_utils.xml" /> <xi:include href="xml/misc_utils.xml" />
<xi:include href="xml/scanner.xml" /> <xi:include href="xml/scanner.xml" />
<xi:include href="xml/completion.xml" />
<xi:include href="xml/timers.xml" /> <xi:include href="xml/timers.xml" />
<xi:include href="xml/spawn.xml" /> <xi:include href="xml/spawn.xml" />
<xi:include href="xml/fileutils.xml" /> <xi:include href="xml/fileutils.xml" />
@ -120,7 +119,6 @@ synchronize their operation.
<xi:include href="xml/quarks.xml" /> <xi:include href="xml/quarks.xml" />
<xi:include href="xml/datalist.xml" /> <xi:include href="xml/datalist.xml" />
<xi:include href="xml/datasets.xml" /> <xi:include href="xml/datasets.xml" />
<xi:include href="xml/relations.xml" />
<xi:include href="xml/caches.xml" /> <xi:include href="xml/caches.xml" />
<xi:include href="xml/gvarianttype.xml"/> <xi:include href="xml/gvarianttype.xml"/>
<xi:include href="xml/gvariant.xml"/> <xi:include href="xml/gvariant.xml"/>
@ -128,6 +126,13 @@ synchronize their operation.
<xi:include href="gvariant-text.xml"/> <xi:include href="gvariant-text.xml"/>
</chapter> </chapter>
<chapter id="deprecated">
<title>Deprecated APIs</title>
<xi:include href="xml/threads-deprecated.xml"/>
<xi:include href="xml/relations.xml" />
<xi:include href="xml/completion.xml" />
</chapter>
<chapter id="tools"> <chapter id="tools">
<title>GLib Tools</title> <title>GLib Tools</title>
<xi:include href="glib-gettextize.xml" /> <xi:include href="glib-gettextize.xml" />

View File

@ -9,7 +9,7 @@
</MACRO> </MACRO>
<MACRO> <MACRO>
<NAME>G_THREADS_IMPL_NONE</NAME> <NAME>G_THREADS_IMPL_WIN32</NAME>
#define G_THREADS_IMPL_NONE #define G_THREADS_IMPL_NONE
</MACRO> </MACRO>

View File

@ -572,25 +572,17 @@ g_child_watch_funcs
GSourcePrivate GSourcePrivate
</SECTION> </SECTION>
<SECTION> <SECTION>
<TITLE>Threads</TITLE> <TITLE>Threads</TITLE>
<FILE>threads</FILE> <FILE>threads</FILE>
<SUBSECTION>
G_THREADS_IMPL_POSIX
G_THREADS_IMPL_WIN32
<SUBSECTION> <SUBSECTION>
G_THREAD_ERROR G_THREAD_ERROR
GThreadError GThreadError
<SUBSECTION> <SUBSECTION>
g_thread_init
g_thread_supported
g_thread_get_initialized
<SUBSECTION>
GThreadFunc
GThread GThread
GThreadFunc
g_thread_new g_thread_new
g_thread_new_full g_thread_new_full
g_thread_self g_thread_self
@ -598,23 +590,6 @@ g_thread_join
g_thread_yield g_thread_yield
g_thread_exit g_thread_exit
<SUBSECTION Deprecated>
g_thread_create
g_thread_create_full
GThreadPriority
g_thread_set_priority
g_thread_foreach
<SUBSECTION>
GMutex
g_mutex_init
g_mutex_clear
g_mutex_new
g_mutex_free
g_mutex_lock
g_mutex_trylock
g_mutex_unlock
<SUBSECTION> <SUBSECTION>
G_LOCK_DEFINE G_LOCK_DEFINE
G_LOCK_DEFINE_STATIC G_LOCK_DEFINE_STATIC
@ -623,6 +598,14 @@ G_LOCK
G_TRYLOCK G_TRYLOCK
G_UNLOCK G_UNLOCK
<SUBSECTION>
GMutex
g_mutex_init
g_mutex_clear
g_mutex_lock
g_mutex_trylock
g_mutex_unlock
<SUBSECTION> <SUBSECTION>
GRecMutex GRecMutex
g_rec_mutex_init g_rec_mutex_init
@ -644,8 +627,6 @@ g_rw_lock_reader_unlock
<SUBSECTION> <SUBSECTION>
GCond GCond
g_cond_new
g_cond_free
g_cond_init g_cond_init
g_cond_clear g_cond_clear
g_cond_wait g_cond_wait
@ -661,9 +642,6 @@ g_private_get
g_private_set g_private_set
g_private_replace g_private_replace
<SUBSECTION Deprecated>
g_private_new
<SUBSECTION> <SUBSECTION>
GOnce GOnce
GOnceStatus GOnceStatus
@ -680,7 +658,41 @@ g_pointer_bit_lock
g_pointer_bit_trylock g_pointer_bit_trylock
g_pointer_bit_unlock g_pointer_bit_unlock
<SUBSECTION Deprecated> <SUBSECTION Private>
G_LOCK_NAME
atexit
g_thread_error_quark
g_once_impl
</SECTION>
<SECTION>
<TITLE>Deprecated Thread APIs</TITLE>
<FILE>threads-deprecated</FILE>
<SUBSECTION>
G_THREADS_IMPL_POSIX
G_THREADS_IMPL_WIN32
<SUBSECTION>
g_thread_init
g_thread_supported
g_thread_get_initialized
<SUBSECTION>
g_thread_create
g_thread_create_full
GThreadPriority
g_thread_set_priority
g_thread_foreach
<SUBSECTION>
g_mutex_new
g_mutex_free
g_cond_new
g_cond_free
g_private_new
<SUBSECTION>
GStaticMutex GStaticMutex
G_STATIC_MUTEX_INIT G_STATIC_MUTEX_INIT
g_static_mutex_init g_static_mutex_init
@ -690,7 +702,7 @@ g_static_mutex_unlock
g_static_mutex_get_mutex g_static_mutex_get_mutex
g_static_mutex_free g_static_mutex_free
<SUBSECTION Deprecated> <SUBSECTION>
GStaticRecMutex GStaticRecMutex
G_STATIC_REC_MUTEX_INIT G_STATIC_REC_MUTEX_INIT
g_static_rec_mutex_init g_static_rec_mutex_init
@ -701,7 +713,7 @@ g_static_rec_mutex_lock_full
g_static_rec_mutex_unlock_full g_static_rec_mutex_unlock_full
g_static_rec_mutex_free g_static_rec_mutex_free
<SUBSECTION Deprecated> <SUBSECTION>
GStaticRWLock GStaticRWLock
G_STATIC_RW_LOCK_INIT G_STATIC_RW_LOCK_INIT
g_static_rw_lock_init g_static_rw_lock_init
@ -713,7 +725,7 @@ g_static_rw_lock_writer_trylock
g_static_rw_lock_writer_unlock g_static_rw_lock_writer_unlock
g_static_rw_lock_free g_static_rw_lock_free
<SUBSECTION Deprecated> <SUBSECTION>
GStaticPrivate GStaticPrivate
G_STATIC_PRIVATE_INIT G_STATIC_PRIVATE_INIT
g_static_private_init g_static_private_init
@ -725,22 +737,12 @@ g_static_private_free
GThreadFunctions GThreadFunctions
G_THREADS_ENABLED G_THREADS_ENABLED
g_static_mutex_get_mutex_impl g_static_mutex_get_mutex_impl
g_static_mutex_get_mutex_impl_shortcut
G_LOCK_NAME
glib_dummy_decl
GSystemThread GSystemThread
g_thread_use_default_impl g_thread_use_default_impl
g_threads_got_initialized g_threads_got_initialized
g_thread_functions_for_glib_use g_thread_functions_for_glib_use
g_thread_gettime g_thread_gettime
g_thread_init_glib
g_thread_error_quark
g_once_impl
g_once_init_enter_impl g_once_init_enter_impl
atexit
g_system_thread_assign
g_system_thread_equal
g_system_thread_equal_simple
</SECTION> </SECTION>
<SECTION> <SECTION>

View File

@ -74,6 +74,24 @@
* to initialize the thread system. * to initialize the thread system.
*/ */
/**
* G_THREADS_IMPL_POSIX:
*
* This macro is defined if POSIX style threads are used.
*
* Deprecated:2.32:POSIX threads are in use on all non-Windows systems.
* Use G_OS_WIN32 to detect Windows.
*/
/**
* G_THREADS_IMPL_WIN32:
*
* This macro is defined if Windows style threads are used.
*
* Deprecated:2.32:Use G_OS_WIN32 to detect Windows.
*/
/* {{{1 Exported Variables */ /* {{{1 Exported Variables */
gboolean g_thread_use_default_impl = TRUE; gboolean g_thread_use_default_impl = TRUE;

View File

@ -139,7 +139,7 @@ g_mutex_get_impl (GMutex *mutex)
* This function is useful to initialize a mutex that has been * This function is useful to initialize a mutex that has been
* allocated on the stack, or as part of a larger structure. * allocated on the stack, or as part of a larger structure.
* It is not necessary to initialize a mutex that has been * It is not necessary to initialize a mutex that has been
* created with g_mutex_new() or that has been statically allocated. * created that has been statically allocated.
* *
* |[ * |[
* typedef struct { * typedef struct {
@ -173,8 +173,8 @@ g_mutex_init (GMutex *mutex)
* *
* Frees the resources allocated to a mutex with g_mutex_init(). * Frees the resources allocated to a mutex with g_mutex_init().
* *
* #GMutexes that have have been created with g_mutex_new() should * This function should not be used with a #GMutex that has been
* be freed with g_mutex_free() instead. * statically allocated.
* *
* Calling g_mutex_clear() on a locked mutex leads to undefined * Calling g_mutex_clear() on a locked mutex leads to undefined
* behaviour. * behaviour.
@ -199,9 +199,9 @@ g_mutex_clear (GMutex *mutex)
* called, and, in that case, will do nothing. * called, and, in that case, will do nothing.
* *
* <note>#GMutex is neither guaranteed to be recursive nor to be * <note>#GMutex is neither guaranteed to be recursive nor to be
* non-recursive, i.e. a thread could deadlock while calling * non-recursive. As such, calling g_mutex_lock() on a #GMutex that has
* g_mutex_lock(), if it already has locked @mutex. Use * already been locked by the same thread results in undefined behaviour
* #GRecMutex if you need recursive mutexes.</note> * (including but not limited to deadlocks).</note>
*/ */
void void
g_mutex_lock (GMutex *mutex) g_mutex_lock (GMutex *mutex)
@ -246,9 +246,10 @@ g_mutex_unlock (GMutex *mutex)
* called, and, in that case, will immediately return %TRUE. * called, and, in that case, will immediately return %TRUE.
* *
* <note>#GMutex is neither guaranteed to be recursive nor to be * <note>#GMutex is neither guaranteed to be recursive nor to be
* non-recursive, i.e. the return value of g_mutex_trylock() could be * non-recursive. As such, calling g_mutex_lock() on a #GMutex that has
* both %FALSE or %TRUE, if the current thread already has locked * already been locked by the same thread results in undefined behaviour
* @mutex. Use #GRecMutex if you need recursive mutexes.</note> * (including but not limited to deadlocks or arbitrary return values).
* </note>
* Returns: %TRUE if @mutex could be locked * Returns: %TRUE if @mutex could be locked
*/ */
@ -315,9 +316,9 @@ g_rec_mutex_get_impl (GRecMutex *rec_mutex)
* This function is useful to initialize a recursive mutex * This function is useful to initialize a recursive mutex
* that has been allocated on the stack, or as part of a larger * that has been allocated on the stack, or as part of a larger
* structure. * structure.
* It is not necessary to initialize a recursive mutex that has *
* been created with g_rec_mutex_new(). It is not necessary to * It is not necessary to initialise a recursive mutex that has been
* initialise a recursive mutex that has been statically allocated. * statically allocated.
* *
* |[ * |[
* typedef struct { * typedef struct {
@ -352,8 +353,8 @@ g_rec_mutex_init (GRecMutex *rec_mutex)
* Frees the resources allocated to a recursive mutex with * Frees the resources allocated to a recursive mutex with
* g_rec_mutex_init(). * g_rec_mutex_init().
* *
* #GRecMutexes that have have been created with g_rec_mutex_new() * This function should not be used with a #GRecMutex that has been
* should be freed with g_rec_mutex_free() instead. * statically allocated.
* *
* Calling g_rec_mutex_clear() on a locked recursive mutex leads * Calling g_rec_mutex_clear() on a locked recursive mutex leads
* to undefined behaviour. * to undefined behaviour.
@ -509,6 +510,9 @@ g_rw_lock_init (GRWLock *rw_lock)
* *
* Frees the resources allocated to a lock with g_rw_lock_init(). * Frees the resources allocated to a lock with g_rw_lock_init().
* *
* This function should not be used with a #GRWLock that has been
* statically allocated.
*
* Calling g_rw_lock_clear() when any thread holds the lock * Calling g_rw_lock_clear() when any thread holds the lock
* leads to undefined behaviour. * leads to undefined behaviour.
* *
@ -681,7 +685,7 @@ g_cond_get_impl (GCond *cond)
* This function is useful to initialize a #GCond that has been * This function is useful to initialize a #GCond that has been
* allocated on the stack, or as part of a larger structure. * allocated on the stack, or as part of a larger structure.
* It is not necessary to initialize a #GCond that has been * It is not necessary to initialize a #GCond that has been
* created with g_cond_new() or that has been statically allocated. * statically allocated.
* *
* To undo the effect of g_cond_init() when a #GCond is no longer * To undo the effect of g_cond_init() when a #GCond is no longer
* needed, use g_cond_clear(). * needed, use g_cond_clear().
@ -703,8 +707,8 @@ g_cond_init (GCond *cond)
* *
* Frees the resources allocated to a #GCond with g_cond_init(). * Frees the resources allocated to a #GCond with g_cond_init().
* *
* #GConds that have been created with g_cond_new() should * This function should not be used with a #GCond that has been
* be freed with g_cond_free() instead. * statically allocated.
* *
* Calling g_cond_clear() for a #GCond on which threads are * Calling g_cond_clear() for a #GCond on which threads are
* blocking leads to undefined behaviour. * blocking leads to undefined behaviour.
@ -1116,8 +1120,6 @@ g_system_thread_create (GThreadFunc thread_func,
* that other threads can run. * that other threads can run.
* *
* This function is often used as a method to make busy wait less evil. * This function is often used as a method to make busy wait less evil.
* But in most cases you will encounter, there are better methods to do
* that. So in general you shouldn't use this function.
*/ */
void void
g_thread_yield (void) g_thread_yield (void)

View File

@ -106,18 +106,6 @@
* are also thread-safe. * are also thread-safe.
*/ */
/**
* G_THREADS_IMPL_POSIX:
*
* This macro is defined if POSIX style threads are used.
*/
/**
* G_THREADS_IMPL_WIN32:
*
* This macro is defined if Windows style threads are used.
*/
/* G_LOCK Documentation {{{1 ---------------------------------------------- */ /* G_LOCK Documentation {{{1 ---------------------------------------------- */
/** /**
@ -224,75 +212,10 @@
* *
* It is easy to see that this won't work in a multi-threaded * It is easy to see that this won't work in a multi-threaded
* application. There current_number must be protected against shared * application. There current_number must be protected against shared
* access. A first naive implementation would be: * access. A #GMutex can be used as a solution to this problem:
* *
* <example> * <example>
* <title>The wrong way to write a thread-safe function</title> * <title>Using GMutex to protected a shared variable</title>
* <programlisting>
* int
* give_me_next_number (void)
* {
* static int current_number = 0;
* int ret_val;
* static GMutex * mutex = NULL;
*
* if (!mutex) mutex = g_mutex_new (<!-- -->);
*
* g_mutex_lock (mutex);
* ret_val = current_number = calc_next_number (current_number);
* g_mutex_unlock (mutex);
*
* return ret_val;
* }
* </programlisting>
* </example>
*
* This looks like it would work, but there is a race condition while
* constructing the mutex and this code cannot work reliable. Please do
* not use such constructs in your own programs! One working solution
* is:
*
* <example>
* <title>A correct thread-safe function</title>
* <programlisting>
* static GMutex *give_me_next_number_mutex = NULL;
*
* /<!-- -->* this function must be called before any call to
* * give_me_next_number(<!-- -->)
* *
* * it must be called exactly once.
* *<!-- -->/
* void
* init_give_me_next_number (void)
* {
* g_assert (give_me_next_number_mutex == NULL);
* give_me_next_number_mutex = g_mutex_new (<!-- -->);
* }
*
* int
* give_me_next_number (void)
* {
* static int current_number = 0;
* int ret_val;
*
* g_mutex_lock (give_me_next_number_mutex);
* ret_val = current_number = calc_next_number (current_number);
* g_mutex_unlock (give_me_next_number_mutex);
*
* return ret_val;
* }
* </programlisting>
* </example>
*
* If a #GMutex is allocated in static storage then it can be used
* without initialisation. Otherwise, you should call g_mutex_init() on
* it and g_mutex_clear() when done.
*
* A statically initialized #GMutex provides an even simpler and safer
* way of doing this:
*
* <example>
* <title>Using a statically allocated mutex</title>
* <programlisting> * <programlisting>
* int * int
* give_me_next_number (void) * give_me_next_number (void)
@ -310,6 +233,13 @@
* </programlisting> * </programlisting>
* </example> * </example>
* *
* Notice that the #GMutex is not initialised to any particular value.
* Its placement in static storage ensures that it will be initialised
* to all-zeros, which is appropriate.
*
* If a #GMutex is placed in other contexts (eg: embedded in a struct)
* then it must be explicitly initialised using g_mutex_init().
*
* A #GMutex should only be accessed via <function>g_mutex_</function> * A #GMutex should only be accessed via <function>g_mutex_</function>
* functions. * functions.
*/ */
@ -485,6 +415,9 @@
* is returned by g_thread_new() or g_thread_new_full(). You can * is returned by g_thread_new() or g_thread_new_full(). You can
* obtain the #GThread struct representing the current thead by * obtain the #GThread struct representing the current thead by
* calling g_thread_self(). * calling g_thread_self().
*
* The structure is opaque -- none of its fields may be directly
* accessed.
*/ */
/** /**
@ -789,15 +722,15 @@ g_thread_create_proxy (gpointer data)
* @joinable: should this thread be joinable? * @joinable: should this thread be joinable?
* @error: return location for error * @error: return location for error
* *
* This function creates a new thread. The new thread starts by * This function creates a new thread. The new thread starts by invoking
* invoking @func with the argument data. The thread will run * @func with the argument data. The thread will run until @func returns
* until @func returns or until g_thread_exit() is called. * or until g_thread_exit() is called from the new thread.
* *
* The @name can be useful for discriminating threads in * The @name can be useful for discriminating threads in
* a debugger. Some systems restrict the length of @name to * a debugger. Some systems restrict the length of @name to
* 16 bytes. * 16 bytes.
* *
* If @joinable is %TRUE, you can wait for this threads termination * If @joinable is %TRUE, you can wait for this thread's termination
* calling g_thread_join(). Resources for a joinable thread are not * calling g_thread_join(). Resources for a joinable thread are not
* fully released until g_thread_join() is called for that thread. * fully released until g_thread_join() is called for that thread.
* Otherwise the thread will just disappear when it terminates. * Otherwise the thread will just disappear when it terminates.
@ -843,7 +776,7 @@ g_thread_new (const gchar *name,
* In most cases, using g_thread_new() (which doesn't take a * In most cases, using g_thread_new() (which doesn't take a
* @stack_size) is better. * @stack_size) is better.
* *
* If @joinable is %TRUE, you can wait for this threads termination * If @joinable is %TRUE, you can wait for this thread's termination
* calling g_thread_join(). Resources for a joinable thread are not * calling g_thread_join(). Resources for a joinable thread are not
* fully released until g_thread_join() is called for that thread. * fully released until g_thread_join() is called for that thread.
* Otherwise the thread will just disappear when it terminates. * Otherwise the thread will just disappear when it terminates.