mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-25 21:46:14 +01:00
Add a finalization performance test
This commit is contained in:
parent
7de0fcd628
commit
1c4f6da1f7
@ -521,6 +521,48 @@ test_construction_teardown (PerformanceTest *test,
|
|||||||
g_free (data);
|
g_free (data);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
test_finalization_init (PerformanceTest *test,
|
||||||
|
gpointer _data,
|
||||||
|
double count_factor)
|
||||||
|
{
|
||||||
|
struct ConstructionTest *data = _data;
|
||||||
|
int n;
|
||||||
|
|
||||||
|
n = NUM_OBJECT_TO_CONSTRUCT * count_factor;
|
||||||
|
if (data->n_objects != n)
|
||||||
|
{
|
||||||
|
data->n_objects = n;
|
||||||
|
data->objects = g_new (GObject *, n);
|
||||||
|
}
|
||||||
|
|
||||||
|
for (int i = 0; i < data->n_objects; i++)
|
||||||
|
{
|
||||||
|
data->objects[i] = g_object_new (data->type, NULL);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
test_finalization_run (PerformanceTest *test,
|
||||||
|
gpointer _data)
|
||||||
|
{
|
||||||
|
struct ConstructionTest *data = _data;
|
||||||
|
GObject **objects = data->objects;
|
||||||
|
int i, n_objects;
|
||||||
|
|
||||||
|
n_objects = data->n_objects;
|
||||||
|
for (i = 0; i < n_objects; i++)
|
||||||
|
{
|
||||||
|
g_object_unref (objects[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
test_finalization_finish (PerformanceTest *test,
|
||||||
|
gpointer _data)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
test_construction_print_result (PerformanceTest *test,
|
test_construction_print_result (PerformanceTest *test,
|
||||||
gpointer _data,
|
gpointer _data,
|
||||||
@ -532,6 +574,17 @@ test_construction_print_result (PerformanceTest *test,
|
|||||||
data->n_objects / (time * 1000000));
|
data->n_objects / (time * 1000000));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
test_finalization_print_result (PerformanceTest *test,
|
||||||
|
gpointer _data,
|
||||||
|
double time)
|
||||||
|
{
|
||||||
|
struct ConstructionTest *data = _data;
|
||||||
|
|
||||||
|
g_print ("Millions of finalized objects per second: %.3f\n",
|
||||||
|
data->n_objects / (time * 1000000));
|
||||||
|
}
|
||||||
|
|
||||||
/*************************************************************
|
/*************************************************************
|
||||||
* Test runtime type check performance
|
* Test runtime type check performance
|
||||||
*************************************************************/
|
*************************************************************/
|
||||||
@ -890,6 +943,16 @@ static PerformanceTest tests[] = {
|
|||||||
test_construction_teardown,
|
test_construction_teardown,
|
||||||
test_construction_print_result
|
test_construction_print_result
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"finalization",
|
||||||
|
simple_object_get_type,
|
||||||
|
test_construction_setup,
|
||||||
|
test_finalization_init,
|
||||||
|
test_finalization_run,
|
||||||
|
test_finalization_finish,
|
||||||
|
test_construction_teardown,
|
||||||
|
test_finalization_print_result
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"type-check",
|
"type-check",
|
||||||
NULL,
|
NULL,
|
||||||
|
Loading…
Reference in New Issue
Block a user