ОБЗОР
#define _GNU_SOURCE /* смотрите feature_test_macros(7) */
#include <signal.h>
typedef void (*sighandler_t)(int);
sighandler_t sysv_signal(int signum, sighandler_t handler);
ОПИСАНИЕ
Функция sysv_signal() ожидает те же аргументы и выполняет ту же задачу,
что и signal(2).
Однако sysv_signal() предоставляет ненадёжную семантику сигналов System V, то есть: a) обработчик сигнала сбрасывается в значение по умолчанию, при его вызове; b) доставка последующих экземпляров сигнала не блокируется на время выполнения обработчика сигнала; c) если обработчик сигнала прерывает (некоторые) блокирующие системные вызовы, то системный вызов автоматически не перезапускается.
ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ
Функция sysv_signal() возвращает предыдущее значение обработчика сигнала
или SIG_ERR при ошибке.
ОШИБКИ
Как в signal(2).
АТРИБУТЫ
Описание терминов данного раздела смотрите в attributes(7).
Интерфейс Атрибут Значение
sysv_signal()
безвредность в потоках: безвредно (MT-Safe)
СООТВЕТСТВИЕ СТАНДАРТАМ
Эта функция не является стандартной.
ЗАМЕЧАНИЯ
Избегайте использования sysv_signal(), используйте вместо неё
sigaction(2).
В старых Linux-системах sysv_signal() и signal(2) были эквивалентны. Однако в новых системах signal(2) предоставляет надежную семантику сигналов. Подробности смотрите в signal(2).
Используемый параметр sighandler_t является расширением GNU; данный тип определён только в том случае, если определён макрос _GNU_SOURCE.