sysv_signal(3) Library Functions Manual sysv_signal(3)

ИМЯ

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

Standard C library (libc, -lc)

СИНТАКСИС

#define _GNU_SOURCE         /* See 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.

СТАНДАРТЫ

None.

СМ. ТАКЖЕ

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

ПЕРЕВОД

Русский перевод этой страницы руководства был сделан Alexander Golubev <fatzer2@gmail.com>, Azamat Hackimov <azamat.hackimov@gmail.com>, Hotellook, Nikita <zxcvbnm3230@mail.ru>, Spiros Georgaras <sng@hellug.gr>, Vladislav <ivladislavefimov@gmail.com>, Yuri Kozlov <yuray@komyakino.ru> и Иван Павлов <pavia00@gmail.com>

Этот перевод является бесплатной документацией; прочитайте Стандартную общественную лицензию GNU версии 3 или более позднюю, чтобы узнать об условиях авторского права. Мы не несем НИКАКОЙ ОТВЕТСТВЕННОСТИ.

Если вы обнаружите ошибки в переводе этой страницы руководства, пожалуйста, отправьте электронное письмо на man-pages-ru-talks@lists.sourceforge.net.

20 июля 2023 г. Linux man-pages 6.05.01