ИМЯ

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 содержится код ошибки.

ОШИБКИ

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

АТРИБУТЫ

Описание терминов данного раздела смотрите в attributes(7).
Интерфейс Атрибут Значение
sem_post() Безвредность в нитях MT-Safe
 

СТАНДАРТЫ

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 <[email protected]>, Azamat Hackimov <[email protected]>, Hotellook, Nikita <[email protected]>, Spiros Georgaras <[email protected]>, Vladislav <[email protected]>, Yuri Kozlov <[email protected]> и Иван Павлов <[email protected]>
Этот перевод является бесплатной документацией; прочитайте Стандартную общественную лицензию GNU версии 3 или более позднюю, чтобы узнать об условиях авторского права. Мы не несем НИКАКОЙ ОТВЕТСТВЕННОСТИ.
Если вы обнаружите ошибки в переводе этой страницы руководства, пожалуйста, отправьте электронное письмо на [email protected]

Recommended readings

Pages related to sem_post you should read also: