[glib] gthreadpool: set default max_unused_threads and max_idle_time values
- From: Dan Winship <danw src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [glib] gthreadpool: set default max_unused_threads and max_idle_time values
- Date: Tue, 31 Jul 2012 18:37:59 +0000 (UTC)
commit b3f96373372771744a5ade73b2e897ec32365182
Author: Dan Winship <danw gnome org>
Date: Wed Jul 25 14:41:04 2012 -0400
gthreadpool: set default max_unused_threads and max_idle_time values
GThreadPool defaulted to 0 for max_unused_threads (meaning thread-pool
threads would exit immediately if there was not already another task
waiting for them), and 0 for max_idle_time (meaning unused threads
would linger forever, though this is only relevant if you changed
max_unused_threads).
However, GIOScheduler changed the global defaults to 2 and 15*1000,
respectively, arguing that these were more useful defaults. And they
are, so let's use them.
https://bugzilla.gnome.org/show_bug.cgi?id=661767
gio/gioscheduler.c | 6 ------
glib/gthreadpool.c | 9 +++++----
2 files changed, 5 insertions(+), 10 deletions(-)
---
diff --git a/gio/gioscheduler.c b/gio/gioscheduler.c
index 24c6451..f63996e 100644
--- a/gio/gioscheduler.c
+++ b/gio/gioscheduler.c
@@ -113,12 +113,6 @@ init_scheduler (gpointer arg)
g_thread_pool_set_sort_function (job_thread_pool,
g_io_job_compare,
NULL);
- /* It's kinda weird that this is a global setting
- * instead of per threadpool. However, we really
- * want to cache some threads, but not keep around
- * those threads forever. */
- g_thread_pool_set_max_idle_time (15 * 1000);
- g_thread_pool_set_max_unused_threads (2);
}
}
return NULL;
diff --git a/glib/gthreadpool.c b/glib/gthreadpool.c
index de5b9de..78684ab 100644
--- a/glib/gthreadpool.c
+++ b/glib/gthreadpool.c
@@ -110,9 +110,9 @@ static gint wakeup_thread_serial = 0;
/* Here all unused threads are waiting */
static GAsyncQueue *unused_thread_queue = NULL;
static gint unused_threads = 0;
-static gint max_unused_threads = 0;
+static gint max_unused_threads = 2;
static gint kill_unused_threads = 0;
-static guint max_idle_time = 0;
+static guint max_idle_time = 15 * 1000;
static void g_thread_pool_queue_push_unlocked (GRealThreadPool *pool,
gpointer data);
@@ -829,6 +829,8 @@ g_thread_pool_wakeup_and_stop_all (GRealThreadPool *pool)
* Sets the maximal number of unused threads to @max_threads.
* If @max_threads is -1, no limit is imposed on the number
* of unused threads.
+ *
+ * The default value is 2.
*/
void
g_thread_pool_set_max_unused_threads (gint max_threads)
@@ -964,8 +966,7 @@ g_thread_pool_set_sort_function (GThreadPool *pool,
*
* By setting @interval to 0, idle threads will not be stopped.
*
- * This function makes use of g_async_queue_timed_pop () using
- * @interval.
+ * The default value is 15000 (15 seconds).
*
* Since: 2.10
*/
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]