#include <pthread.h>
int pthread_barrierattr_destroy(pthread_barrierattr_t *attr);
int pthread_barrierattr_init(pthread_barrierattr_t *attr);
The pthread_barrierattr_destroy() function shall destroy a barrier attributes object. A destroyed attr attributes object can be reinitialized using pthread_barrierattr_init(); the results of otherwise referencing the object after it has been destroyed are undefined. An implementation may cause pthread_barrierattr_destroy() to set the object referenced by attr to an invalid value.
The pthread_barrierattr_init() function shall initialize a barrier attributes object attr with the default value for all of the attributes defined by the implementation.
Results are undefined if pthread_barrierattr_init() is called specifying an already initialized attr attributes object.
After a barrier attributes object has been used to initialize one or more barriers, any function affecting the attributes object (including destruction) shall not affect any previously initialized barrier.
If successful, the pthread_barrierattr_destroy() and pthread_barrierattr_init() functions shall return zero; otherwise, an error number shall be returned to indicate the error.
The pthread_barrierattr_destroy() function may fail if:
The pthread_barrierattr_init() function shall fail if:
These functions shall not return an error code of [EINTR].
The following sections are informative.
The pthread_barrierattr_destroy() and pthread_barrierattr_init() functions are part of the Barriers option and need not be provided on all implementations.
pthread_barrierattr_getpshared(), pthread_barrierattr_setpshared(), the Base Definitions volume of IEEE Std 1003.1-2001, <pthread.h>.