sem_release

(PHP 4, PHP 5, PHP 7, PHP 8)

sem_releaseОсвобождает семафор

Описание

sem_release(SysvSemaphore $semaphore): bool

Функция sem_release() освобождает семафор, если его захватил вызывающий процесс, иначе генерируется предупреждение.

После освобождения разрешается повторно захватывать семафор функцией sem_acquire().

Список параметров

semaphore

Семафор, который вернула функция sem_get().

Возвращаемые значения

Функция возвращает true, если выполнилась успешно, или false, если возникла ошибка.

Список изменений

Версия Описание
8.0.0 Параметр semaphore теперь ожидает экземпляр класса SysvSemaphore; раньше ожидался ресурс (resource).

Смотрите также

  • sem_get() - Получает идентификатор семафора
  • sem_acquire() - Захватывает семафор

Добавить

Примечания пользователей 2 notes

up
2
danno at circumsolutions dot com
23 years ago
If you want to implement this sort of semaphore access (which is usually what is needed if doing ipc) one thing you can do is create shared memory which is simply an int. Use this int between processes as the value of the semaphore. You can write wrapper functions which use this to allow you to do the desired readers-writers stuff or just use the shared memory plain. I wouldn't be too worried about race conditions in this case as the shared memory is only an int. If you are worried about race conditions, the wrapper functions for doing the semaphore stuff could actually use a semaphore to elimate any race conditions. Also, an added bonus of doing it this way is you can check the value of the int.
up
1
apua at communiplex dot com
25 years ago
The fact that sem_release only resease the semaphore if it is currently acquired by the calling process is, in fact, a misfeature since sometimes (eg in a readers-writers implementation) it is desirable to release a semaphore acquired by another process. In C you can do that.
I'm telling this because I was trying to write a chat app in php3 made of two programs: a listener and a speaker. The speaker releases a semaphore to inform that there is a new message in a shared memory var. And listeners wait in that semaphore before outputting the message.
To Top