Создать дочерний процесс с заданным списком аргументов
#include <process.h>int spawnl( int mode,const char *path,const char *arg0,const char *arg1,...const char *argn,NULL );
NULL
недопустимо). Список аргументов должен завершаться NULL
.libc
Функция spawnl() создает и исполняет новый дочерний процесс на основе файла path с использованием NULL
-терминированного списка аргументов в arg0 ... argn. Функция неявно вызывает spawnve().
Если новый процесс является shell-скриптом, то его первая строка должна начинаться с #! с последующим именем программы-интерпретатора (опционально могут быть также переданы его аргументы). Скрипт также должен иметь разрешения на исполнение. |
Данная функция не является частью стандарта POSIX 1003.1 и не дает гарантии одинакового исполнения во всех операционных системах. Она формирует массив argv[] перед неявным вызовом spawn().
Перечисленные на рисунке функции в конечном счете вызывают spawn():
Аргументы передаются дочернему процессу путем передачи одного или нескольких указателей на соответствующие строки. При передаче потомку они объединяются, но каждый аргумент разделяется пробелом.
Дочерний процесс наследует переменные окружения родителя (или просто окружение). Их значения могут быть определены утилитами export и env или функциями putenv() и setenv(). Программа может считать их через функцию getenv().
Отношения родитель-потомок не означают, что потомок будет завершен при смерти родителя. |
Функция возвращает значение в зависимости от аргумента mode:
P_WAIT
P_NOWAIT
P_NOWAITO
0
, если процесс порожден на удаленном узле. Получение кода завершения потомка невозможно. Если возникла ошибка функция возвращает -1
, код ошибки записывается в errno.
Функция устанавливает коды ошибок, используемые spawn(), и дополнительно:
P_WAIT
, но потомок завершился до вызова waitpid() родителем. Исполнение команды:
myprog ARG1 ARG2
в исходном коде выполняется следующим образом:
#include <stddef.h>#include <process.h>int exit_val;...exit_val = spawnl( P_WAIT, "myprog", "myprog", "ARG1", "ARG2", NULL );...
Программа myprog будет найдена в том случае, если она размещена в текущей директории.
ЗОСРВ «Нейтрино»
Если mode равно P_WAIT
, данная функция является точкой остановки потока.
execl(), execle(), execlp(), execlpe(), execv(), execve(), execvp(), execvpe(), getenv(), putenv(), setenv(), spawn(), spawnle(), spawnlp(), spawnlpe(), spawnp(), spawnv(), spawnve(), spawnvp(), spawnvpe(), wait(), waitpid()
Предыдущий раздел: Описание API системной библиотеки