NAME
wait3, wait4 - wait for process to change state, BSD style
SYNOPSIS
#define _BSD_SOURCE
/* Or #define _XOPEN_SOURCE 500 for wait3() */
#include <sys/types.h>
#include <sys/time.h>
#include <sys/resource.h>
#include <sys/wait.h>
I pid_t wait3(int * status , int options ,
I struct rusage * rusage );
I pid_t wait4(pid_t pid , int * status , int options ,
I struct rusage * rusage );
DESCRIPTION
The
R wait3 ()
and
R wait4 ()
system calls are similar to
waitpid(2),
but additionally return resource usage information about the
child in the structure pointed to by
R rusage .
Other than the use of the
rusage
argument, the following
R wait3 ()
call:
wait3(status, options, rusage);
is equivalent to:
waitpid(-1, status, options);
Similarly, the following
R wait4 ()
call:
wait4(pid, status, options, rusage);
is equivalent to:
waitpid(pid, status, options);
In other words,
R wait3 ()
waits of any child, while
R wait4 ()
can be used to select a specific child, or children, on which to wait.
See
wait(2)
for further details.
If
rusage
is not NULL, the
struct rusage
to which it points will be filled with accounting information
about the child.
See
getrusage(2)
for details.
RETURN VALUE
ERRORS
CONFORMING TO
4.3BSD
NOTES
Including
<sys/time.h>
is not required these days, but increases portability.
(Indeed,
<sys/resource.h>
defines the
rusage
structure with fields of type
struct timeval
defined in
R <sys/time.h> .)
SEE ALSO