SYSV_SIGNAL(3) Руководство программиста Linux SYSV_SIGNAL(3)

ИМЯ

sysv_signal - обрабатывает сигналы согласно семантике System V

ОБЗОР

#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.

СМОТРИТЕ ТАКЖЕ

sigaction(2), signal(2), bsd_signal(3), signal(7)

2017-09-15