在Linux下,waitpid()函数用于等待指定的子进程状态改变,它的原型如下:
#include#include pid_t waitpid(pid_t pid, int *status, int options);
其中,pid
参数指定要等待的子进程ID,可以有以下几种取值:
-
如果pid > 0,则表示等待具有指定进程ID的子进程;
-
如果pid == 0,则表示等待与调用进程属于同一个进程组的任意子进程;
-
如果pid == -1,则表示等待任意子进程,类似于wait()函数;
-
如果pid < -1,则表示等待进程组ID等于pid绝对值的任意子进程。
status
参数是一个整数指针,用于存储子进程的终止状态,可以为NULL。
options
参数用于设置等待的行为,可以是以下取值的组合:
-
WCONTINUED:等待一个被暂停的子进程恢复执行;
-
WNOHANG:如果没有子进程状态发生改变,则立即返回,而不阻塞;
-
WUNTRACED:等待一个被暂停的子进程或已经终止的子进程;
-
WSTOPPED:等待一个被暂停的子进程。
waitpid()函数的返回值是子进程的进程ID,如果出错则返回-1。
示例代码如下:
#include#include #include #include #include int main() { pid_t pid; int status; pid = fork(); if (pid < 0) { perror("fork"); exit(1); } else if (pid == 0) { // 子进程 printf("Child process: PID=%d\n", getpid()); sleep(5); exit(0); } else { // 父进程 printf("Parent process: PID=%d, Child PID=%d\n", getpid(), pid); waitpid(pid, &status, 0); if (WIFEXITED(status)) { printf("Child process exited with status %d\n", WEXITSTATUS(status)); } else if (WIFSIGNALED(status)) { printf("Child process terminated by signal %d\n", WTERMSIG(status)); } else if (WIFSTOPPED(status)) { printf("Child process stopped by signal %d\n", WSTOPSIG(status)); } } return 0; }
在上面的示例代码中,父进程通过fork()函数创建了一个子进程,然后使用waitpid()函数等待子进程的状态改变。在子进程中,它会暂停5秒钟后退出。父进程在waitpid()函数返回后,根据子进程的终止状态输出相应的信息。
注意,waitpid()函数中的status参数需要传入一个指针,用于存储子进程的终止状态。可以通过宏函数WIFEXITED、WEXITSTATUS、WIFSIGNALED、WTERMSIG、WIFSTOPPED和WSTOPSIG来判断子进程是正常退出、异常终止还是被暂停等。