Name

Caches — sharing of complex data structures, in order to save system resources.


Library

glib.lib


Synopsis

#include <glib.h>

GCache;
GCache* g_cache_new (GCacheNewFunc value_new_func, GCacheDestroyFunc value_destroy_func, GCacheDupFunc key_dup_func, GCacheDestroyFunc key_destroy_func, GHashFunc hash_key_func, GHashFunc hash_value_func, GEqualFunc key_equal_func);
gpointer g_cache_insert (GCache *cache, gpointer key);
void g_cache_remove (GCache *cache, gconstpointer value);
void g_cache_destroy (GCache *cache);

void g_cache_key_foreach (GCache *cache, GHFunc func, gpointer user_data);
void g_cache_value_foreach (GCache *cache, GHFunc func, gpointer user_data);

void (*GCacheDestroyFunc) (gpointer value);
gpointer (*GCacheDupFunc) (gpointer value);
gpointer (*GCacheNewFunc) (gpointer key);

Detailed Description

A GCache allows sharing of complex data structures, in order to save system resources.

GTK+ uses caches for GtkStyles and GdkGCs. These consume a lot of resources, so a GCache is used to see if a GtkStyle or GdkGC with the required properties already exists. If it does, then the existing object is used instead of creating a new one.

GCache uses keys and values. A GCache key describes the properties of a particular resource. A GCache value is the actual resource.


Details

GCache

typedef struct _GCache GCache;

The GCache struct is an opaque data structure containing information about a GCache. It should only be accessed via the following functions.


g_cache_new ()

GCache*     g_cache_new              (GCacheNewFunc value_new_func, GCacheDestroyFunc value_destroy_func, 
                                      GCacheDupFunc key_dup_func, GCacheDestroyFunc key_destroy_func, 
                                      GHashFunc hash_key_func, GHashFunc hash_value_func, GEqualFunc key_equal_func);

Creates a new GCache.

value_new_func : a function to create a new object given a key. This is called by g_cache_insert() if an object with the given key does not already exist.
value_destroy_func : a function to destroy an object. It is called by g_cache_remove() when the object is no longer needed (i.e. its reference count drops to 0).
key_dup_func : a function to copy a key. It is called by g_cache_insert() if the key does not already exist in the GCache.
key_destroy_func : a function to destroy a key. It is called by g_cache_remove() when the object is no longer needed (i.e. its reference count drops to 0).
hash_key_func : a function to create a hash value from a key.
hash_value_func : a function to create a hash value from a value.
key_equal_func : a function to compare two keys. It should return TRUE if the two keys are equivalent.
Returns : a new GCache.

g_cache_insert ()

gpointer    g_cache_insert           (GCache *cache, gpointer key);

Gets the value corresponding to the given key, creating it if necessary. It first checks if the value already exists in the GCache, by using the key_equal_func function passed to g_cache_new(). If it does already exist it is returned, and its reference count is increased by one. If the value does not currently exist, if is created by calling the value_new_func. The key is duplicated by calling key_dup_func and the duplicated key and value are inserted into the GCache.

cache : a GCache.
key : a key describing a GCache object.
Returns : a pointer to a GCache value.

g_cache_remove ()

void        g_cache_remove           (GCache *cache, gconstpointer value);

Decreases the reference count of the given value. If it drops to 0 then the value and its corresponding key are destroyed, using the value_destroy_func and key_destroy_func passed to g_cache_new().

cache : a GCache.
value : the value to remove.

g_cache_destroy ()

void        g_cache_destroy          (GCache *cache);

Frees the memory allocated for the GCache.
Note that it does not destroy the keys and values which were contained in the GCache.

cache : a GCache.

g_cache_key_foreach ()

void        g_cache_key_foreach      (GCache *cache, GHFunc func, gpointer user_data);

Calls the given function for each of the keys in the GCache.

Note

func is passed three parameters, the value and key of a cache entry and the user_data. The order of value and key is different from the order in which g_hash_table_foreach() passes key-value pairs to its callback function !


 
cache : a GCache.
func : the function to call with each GCache key.
user_data : user data to pass to the function.

g_cache_value_foreach ()

void        g_cache_value_foreach     (GCache *cache, GHFunc func, gpointer user_data);

Calls the given function for each of the values in the GCache.

Warning

g_cache_value_foreach has been deprecated since version 2.10 and should not be used in newly-written code. The reason is that it passes pointers to internal data structures to func; use g_cache_key_foreach() instead


 
cache : a GCache.
func : the function to call with each GCache value.
user_data : user data to pass to the function.

GCacheDestroyFunc ()

void        (*GCacheDestroyFunc)      (gpointer value);

Specifies the type of the value_destroy_func and key_destroy_func functions passed to g_cache_new(). The functions are passed a pointer to the GCache key or GCache value and should free any memory and other resources associated with it.

value : the GCache value to destroy.

GCacheDupFunc ()

gpointer    (*GCacheDupFunc)          (gpointer value);

Specifies the type of the key_dup_func function passed to g_cache_new(). The function is passed a key (not a value as the prototype implies) and should return a duplicate of the key.

value : the GCache key to destroy (not a GCache value as it seems).
Returns : a copy of the GCache key.

GCacheNewFunc ()

gpointer    (*GCacheNewFunc)          (gpointer key);

Specifies the type of the value_new_func function passed to g_cache_new(). It is passed a GCache key and should create the value corresponding to the key.

key : a GCache key.
Returns : a new GCache value corresponding to the key.

Feedback

For additional information or queries on this page send feedback


© 2008-2009 Nokia Corporation. All rights reserved. This documentation can be used in the connection with this Product to help and support the user.