Closure
Object Hierarchy:
Description:
[ Compact ]
public class Closure
A `GClosure` represents a callback supplied by the programmer.
It will generally comprise a function of some kind and a marshaller used to call it. It is the responsibility of the marshaller to convert the arguments for the invocation from Values into a suitable form, perform the callback on the converted arguments, and transform the return value back into a Value.
In the case of C programs, a closure usually just holds a pointer to a function and maybe a data argument, and the marshaller converts between
Value and native C types. The GObject library provides the GCClosure
type
for this purpose. Bindings for other languages need marshallers which convert between
Values and suitable representations in the runtime of the language in order to use functions written in that language as callbacks. Use
set_marshal to set the marshaller on such a custom closure
implementation.
Within GObject, closures play an important role in the implementation of signals. When a signal is registered, the c_marshaller
argument to @new specifies the default C marshaller for any closure which
is connected to this signal. GObject provides a number of C marshallers for this purpose, see the g_cclosure_marshal_*() functions. Additional
C marshallers can be generated with the glib-genmarshal utility. Closures can be explicitly connected to signals with
connect_closure, but it usually more convenient to let GObject
create a closure automatically by using one of the g_signal_connect_*() functions which take a callback function/user data pair.
Using closures has a number of important advantages over a simple callback function/data pointer combination:
- Closures allow the callee to get the types of the callback parameters, which means that language bindings don't have to write individual glue for each callback type.
- The reference counting of Closure makes it easy to handle reentrancy right; if a callback is removed while it is being invoked, the closure and its parameters won't be freed until the invocation finishes.
- invalidate and invalidation notifiers allow callbacks to be automatically removed when the objects they point to go away.