GSP
Quick Navigator

Search Site

Unix VPS
A - Starter
B - Basic
C - Preferred
D - Commercial
MPS - Dedicated
Previous VPSs
* Sign Up! *

Support
Contact Us
Online Help
Handbooks
Domain Status
Man Pages

FAQ
Virtual Servers
Pricing
Billing
Technical

Network
Facilities
Connectivity
Topology Map

Miscellaneous
Server Agreement
Year 2038
Credits
 

USA Flag

 

 

Man Pages
PTHREAD_JOIN(3) FreeBSD Library Functions Manual PTHREAD_JOIN(3)

pthread_join, pthread_peekjoin_np, pthread_timedjoin_np
inspect thread termination state

POSIX Threads Library (libpthread, -lpthread)

#include <pthread.h>

int
pthread_join(pthread_t thread, void **value_ptr);

#include <pthread_np.h>

int
pthread_peekjoin_np(pthread_t thread, void **value_ptr);

int
pthread_timedjoin_np(pthread_t thread, void **value_ptr, const struct timespec *abstime);

The pthread_join() function suspends execution of the calling thread until the target thread terminates unless the target thread has already terminated.

On return from a successful pthread_join() call with a non-NULL value_ptr argument, the value passed to pthread_exit() by the terminating thread is stored in the location referenced by value_ptr. When a pthread_join() returns successfully, the target thread has been terminated. The results of multiple simultaneous calls to pthread_join() specifying the same target thread are undefined. If the thread calling pthread_join() is cancelled, then the target thread is not detached.

The pthread_timedjoin_np() function is equivalent to the pthread_join() function except it will return ETIMEDOUT if target thread does not exit before specified absolute time passes.

The pthread_peekjoin_np() only peeks into the exit status of the specified thread. If the thread has not exited, the EBUSY error is returned. Otherwise, zero is returned and the thread exit value is optionally stored into the location of *value_ptr. The target thread is left unjoined and can be used as an argument for the pthread_join() family of functions again.

A thread that has exited but remains unjoined counts against [_POSIX_THREAD_THREADS_MAX].

If successful, the described functions return zero. Otherwise an error number is returned to indicate the error or special condition.

The pthread_join(), pthread_peekjoin_np(), and pthread_timedjoin_np() functions will fail if:
[]
The implementation has detected that the value specified by thread does not refer to a joinable thread.
[]
No thread could be found corresponding to that specified by the given thread ID, thread.
[]
A deadlock was detected or the value of thread specifies the calling thread.
[]
The implementation detected that another caller is already waiting on thread.

Additionally, the pthread_timedjoin_np() function will fail if:

[]
The specified absolute time passed while pthread_timedjoin_np() waited for thread exit.

The pthread_peekjoin_np() function will also fail if:

[]
The specified thread has not yet exited.

wait(2), pthread(3), pthread_create(3), pthread_np(3)

The pthread_join() function conforms to ISO/IEC 9945-1:1996 (“POSIX.1”). The pthread_timedjoin_np() function is a FreeBSD extension which first appeared in FreeBSD 6.1. Another extension, the pthread_peekjoin_np() function, first appearead in FreeBSD 13.0.
October 12, 2021 FreeBSD 13.1-RELEASE

Search for    or go to Top of page |  Section 3 |  Main Index

Powered by GSP Visit the GSP FreeBSD Man Page Interface.
Output converted with ManDoc.