Поиск…
Синтаксис
- pid_t getpid (void);
- pid_t getppid (void);
- pid_t fork (void);
- pid_t waitpid (pid_t pid, int * wstatus, int options);
- int execv (const char * path, char * const argv []);
параметры
Функция, Параметр (ы), Возвращаемое значение | Описание |
---|---|
fork() | имя функции |
никто | н / |
Возвращает PID, 0 или -1 | Вызывающий процесс получает PID нового процесса создания или -1 при сбое. Ребенок (вновь созданный процесс) получает 0. В случае сбоя set errno либо EAGAIN либо ENOMEM |
- | - |
execv() | имя функции |
const char *path | Строка, содержащая имя исполняемого файла (может вставлять путь) |
char *const argv[] | Массив указателя строки в качестве аргументов |
Возвращает -1 при отказе | При успешном выполнении эта функция не возвращается. |
- | - |
Создайте дочерний процесс и подождите, пока он не выйдет
Эта программа демонстрирует, как запустить другой процесс с помощью fork()
и дождаться его завершения с помощью waitpid()
:
fork()
создает идентичную копию текущего процесса. Первоначальный процесс - это родительский процесс, а вновь созданный - дочерний процесс. Оба процесса продолжаются ровно послеfork()
.waitpid()
до тех пор, пока дочерний процесс не выйдет или не завершит работу и не вернет код выхода и причины завершения.
#include <unistd.h> /* for fork(), getpid() */
#include <sys/types.h> /* for waitpid() */
#include <sys/wait.h> /* for waitpid() */
#include <stdlib.h> /* for exit() */
#include <stdio.h> /* for printf(), perror() */
int
main(int argc, char *argv[])
{
/* Create child process.
*
* On success, fork() returns the process ID of the child (> 0) to the
* parent and 0 to the child. On error, -1 is returned.
*/
pid_t child_pid = fork();
if (child_pid < 0) {
perror("fork() failed");
exit(EXIT_FAILURE);
} else if (child_pid == 0) {
/* Print message from child process.
*
* getpid() returns the PID (process identifier) of current process,
* which is typically int but doesn't have to be, so we cast it.
*
* getppid() returns the PID of the parent process.
*/
printf("from child: pid=%d, parent_pid=%d\n",
(int)getpid(), (int)getppid());
/* We can do something here, e.g. load another program using exec().
*/
exit(33);
} else if (child_pid > 0) {
/* Print message from parent process.
*/
printf("from parent: pid=%d child_pid=%d\n",
(int)getpid(), (int)child_pid);
/* Wait until child process exits or terminates.
*
* The return value of waitpid() is PID of the child process, while
* its argument is filled with exit code and termination reason.
*/
int status;
pid_t waited_pid = waitpid(child_pid, &status, 0);
if (waited_pid < 0) {
perror("waitpid() failed");
exit(EXIT_FAILURE);
} else if (waited_pid == child_pid) {
if (WIFEXITED(status)) {
/* WIFEXITED(status) returns true if the child has terminated
* normally. In this case WEXITSTATUS(status) returns child's
* exit code.
*/
printf("from parent: child exited with code %d\n",
WEXITSTATUS(status));
}
}
}
exit(EXIT_SUCCESS);
}
Пример вывода:
from parent: pid=2486 child_pid=2487
from child: pid=2487, parent_pid=2486
from parent: child exited with code 33
Скопировано здесь , первоначально созданное М. Гегером.
Modified text is an extract of the original Stack Overflow Documentation
Лицензировано согласно CC BY-SA 3.0
Не связан с Stack Overflow