ОБЗОР
#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.