Scroll to navigation

sem_post(3) Library Functions Manual sem_post(3)

ИМЯ

sem_post - разблокирует семафор

LIBRARY

POSIX threads library (libpthread, -lpthread)

СИНТАКСИС

#include <semaphore.h>
int sem_post(sem_t *sem);

ОПИСАНИЕ

Функция sem_post() увеличивает (разблокирует) семафор, на который указывает sem. Если значение семафора после этого становится больше нуля, то другой процесс или нить заблокированная в вызове sem_wait(3), проснётся и заблокирует семафор.

ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ

При успешном выполнении sem_post() возвращается 0; при ошибке значение семафора остаётся неизменным, возвращается -1, а в errno содержится код ошибки.

ОШИБКИ

Значение sem не является корректным для семафора.
Превышено максимально допустимое значение для семафора.

АТРИБУТЫ

Описание терминов данного раздела смотрите в attributes(7).

Интерфейс Атрибут Значение
sem_post() Безвредность в нитях MT-Safe

СТАНДАРТЫ

POSIX.1-2008.

ИСТОРИЯ

POSIX.1-2001.

ЗАМЕЧАНИЯ

Функция sem_post() безопасна для асинхронных сигналов: её можно использовать внутри обработчика сигналов.

ПРИМЕРЫ

See sem_wait(3) and shm_open(3).

СМ. ТАКЖЕ

sem_getvalue(3), sem_wait(3), sem_overview(7), signal-safety(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