Документация по LinuxLinuxDoc.Ru 🔍

popen, pclose - открывает и закрывает процесс

НАЗВАНИЕ
popen, pclose - открывает и закрывает процесс

СИНТАКСИС
#include

FILE *popen(const char *command, const char *type);

int pclose(FILE *stream);

ОПИСАНИЕ
Функция popen() открывает процесс, создавая канал,
производя fork и вызывая командную оболочку. Так как
канал задается однонаправленным, аргумент type может
указать только на режим чтения или записи, но не на оба
одновременно.

Аргумент command - это указатель на С-строку, содержащую
командную строку для оболочки. Эта команда передается
/bin/sh с помощью флага -c . Интерпретация, если она
необходима, выполняется самой оболочкой. Аргумент mode -
это указатель на C-строку, содержащую символ `r' для
чтения или `w' для записи.

Возвращаемое значение popen() - это обычный поток
ввода-вывода (за исключением того, что он должен быть
закрыт только функцией pclose() , а не fclose()). Запись
в канал передается на стандартный поток ввода команды,
стандартный поток вывода команды передается в канал, кроме
случаев, когда потоки вывода-вывода переопределены самой
командой.

Заметьте, что выходной поток, возвращаемый popen, по
умолчанию полностью буферизирован.

Функция pclose ожидает завершения ассоциированного
процесса и возвращает код выхода так же, как и функция
wait4.

ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ

Функция popen возвращает NULL, если вызовы fork(2) или
pipe(2) завершились ошибкой или если невозможно выделить
необходимый для этого объем памяти.

Функция pclose возвращает -1, если wait4 возвращает ошибку
или если была обнаружена какая-либо другая ошибка.

КОДЫ ОШИБОК

Функция popen не устанавливает errno, если произошла
ошибка выделения памяти. Если вызовы fork() или pipe()
завершились неудачно, в errno вписывается соответствующий
код ошибки. Если аргумент mode неверен, то в переменную
errno заносится значение EINVAL.

Если pclose() не может получить статус дочернего процесса,
то errno устанавливается равным ECHILD.

СООТВЕТСТВИЕ СТАНДАРТАМ
POSIX.2

НАЙДЕННЫЕ ОШИБКИ
Так как открытый для чтения стандартный ввод данных в
команду делает свое смещение поиска доступным процессу,
вызывающему popen() (если исходный процесс выполнял
буферное чтение), то позиция ввода для команды может быть
не той, что ожидается. Таким же образом, открытый для
записи стандартный вывод данных из команды, возможно,
будет спутан с выводом данных из исходного процесса.
Последнего можно избежать, если вызывать fflush(3) перед
исполнением popen.

Ошибка при попытке запуска оболочки неотличима от ошибки
оболочки при попытке запуска программы или от ошибки при
немедленном выходе из команды. Единственным способом их
различения будет установка статуса окончания работы
команды 127.

ПРЕДЫСТОРИЯ

Функции popen() и pclose() появились в версии 7 AT&T UNIX.
Читать новости Linux в Telegram
Linux - popen, pclose - открывает и закрывает процесс
Мы в соцсетях ✉