dispatch_once(3) Library Functions Manual dispatch_once(3)

dispatch_onceexecute a block only once

#include <dispatch/dispatch.h>

void
dispatch_once(dispatch_once_t *predicate, void (^block)(void));

void
dispatch_once_f(dispatch_once_t *predicate, void *context, void (*function)(void *));

The () function provides a simple and efficient mechanism to run an initializer exactly once, similar to pthread_once(3). Well designed code hides the use of lazy initialization. For example:

FILE *getlogfile(void)
{
	static dispatch_once_t pred;
	static FILE *logfile;

	dispatch_once(&pred, ^{
		logfile = fopen(MY_LOG_FILE, "a");
	});

	return logfile;
}

The variable of type dispatch_once_t must have global or static scope. The result of using this type with automatic or dynamic allocation is undefined.

The dispatch_once() function is a wrapper around ().

dispatch(3)

May 1, 2009 Darwin