Читать книгу 📗 "Linux программирование в примерах - Роббинс Арнольд"
Между механизмами, которые ожидают завершения потомков, и сигнальными механизмами, которые мы еще не обсуждали, есть значительное взаимодействие. Что из них описать вначале представляет собой нечто вроде проблемы курицы и яйца; мы решили сначала поговорить сначала о механизмах ожидания порожденного процесса, а глава 10 «Сигналы» дает полный рассказ о сигналах.
Пока достаточно понять, что сигнал является способом уведомления процесса о том, что произошло некоторое событие. Процессы могут генерировать сигналы, которые посылаются самим себе, или сигналы могут посылаться извне другими процессами или пользователем за терминалом. Например, CTRL-C посылает сигнал «прерывания», a CTRL-Z посылает сигнал управления работой «стоп».
По умолчанию, многие сигналы, такие, как сигнал прерывания, заставляют получающий процесс закончиться. Другие, такие, как сигналы управления работами, вызывают изменение его состояния. Механизмы ожидания порожденного процесса могут определить, претерпел ли процесс сигнал завершения, и если да, какой это был сигнал. То же верно и для остановки процесса и, на некоторых системах возобновления процесса.
9.1.6.1. Использование функций POSIX:
wait()waitpid()Первоначальным системным вызовом V7 был
wait()waitpid()#include <sys/types.h> /* POSIX */#include <sys/wait.h>pid_t wait(int *status);pid_t waitpid(pid_t pid, int *status, int options);wait()*status*statusЕсли порожденных процессов нет,
wait()errnoECHILDФункция
waitpid()pid_t pidЗначение указывает, завершения какого порожденного процесса ждать как по-настоящему
pidpidpid < -1 pidpid = -1 wait()pid = 0 pid > 0 pidint *statusТо же, что и для
wait()<sys/wait.h>*statusint optionsЭтот параметр должен быть равен либо 0, либо побитовым ИЛИ одного или более из следующих флагов:
WNOHANGЕсли ни один порожденный процесс не завершился, вернуться немедленно. Таким способом можно периодически проверять, не закончился ли какой- нибудь порожденный процесс. (Такая периодическая проверка известна как опрашивание события.)
WUNTRACEDВернуть сведения о порожденном процессе, который остановился, но еще не завершился. (Например, для управления работой.)
WCONTINUED(XSI.) Вернуть сведения о порожденном процессе, который продолжился, если его статус не сообщался с момента изменения. Это также для управления работой. Этот флаг является расширением XSI и не доступен под GNU/Linux.
С заполненным значением
*statusWIFEXITED(status)Этот макрос не равен нулю (true), если процесс завершился (в противоположность изменению состояния).
WEXITSTATUS(status)Этот макрос дает статус завершения; он равен восьми наименее значимым битам значения, переданного
exit()main()WIFEXIDED(status)WIFSIGNALED(status)Этот макрос не равен нулю, если процесс подвергся действию завершающего сигнала death-by-signal.
WTERMSIG(status)Этот макрос предоставляет номер сигнала, который завершил процесс. Этот макрос следует использовать, лишь когда
WIFSIGNALED(status)WIFSTOPPED(status)Этот макрос не равен нулю, если процесс был остановлен.
WSTOPSIG(status)Этот макрос предоставляет номер сигнала, который остановил процесс. (Процесс остановить могут несколько сигналов.) Этот макрос следует использовать лишь когда
WIFSTOPPED(status)WIFCONTINUED(status)(XSI.) Этот макрос не равен нулю, если процесс был продолжен. Соответствующего макроса
WCONTSIG()Обратите внимание, что этот макрос является расширением XSI и в частности, он недоступен в GNU/Linux. Следовательно, если вы хотите его использовать, заключите код внутри '
#ifdef WIFCONTINUED ... #endifWCOREDUMP(status)(Общий.) Этот макрос не равен нулю, если процесс создал снимок. Снимок процесса (core dump) является образом запущенного процесса в памяти, созданном при завершении процесса. Он предназначен для использования впоследствии при отладке. Системы Unix называют файл
corecorе.<i>pid</i><i>pid</i>