определенной реализации, приложение может избежать статической инициализации, явным образом инициализируя все объекты синхронизации c помощью соответствующих функций
Разрушение мьютексов
Мьютекс можно разрушить сразу после разблокировки. Например, рассмотрим следующий код.
struct obj {
pthread_mutex_t om;
int refcnt;
};
obj_done (struct obj *op) {
pthread_mutex_lock (&op- >om);
if (—op- >refcnt == 0) {
pthread_mutex_unlock (&op- >om);
(A) pthread_mutex_destroy (&op- >om);
(B) free(op); } else
(С) pthread_mutex_unlock (&op->om);
}
В данном случае структура obj служит для учета количества ссылок, а функция obj_done() вызывается всякий раз, когда удаляется ссылка на объект. Реализации должны позволить разрушение объекта и освобождение занимаемых им ресурсов (см. строки А и В) сразу после его разблокировки (строка С).
Будущие направления
Отсутствуют.
Смотри также
pthread_mutex_getprioceiling (), pthread_mutex_lock (), pthread_mutex_timedlock (), pthread_mutexattr_getpshared (), том Base Definitions стандарта IEEE Std 1003.1-2001, <pthread.h>.
Последовательность внесения изменений
Функции впервые реализованы в выпуске Issue 5. Включены для согласования с расширение
Issue 6
Функции pthread_mutex_destroy() и pthread_mutex_init() от
В целях согласования со стандарто
Раздел «Описание» б
В целях согласования со стандартом ISO/IEC 9899: 1999 в прототип функции pthread_mutex_init () было добавлено ключевое слово restrict.
pthread_mutex_getprioceiling, pthread_mutex_setprioceiling
Имя
THR TPP
pthread_mutex_getprioceiling, pthread_mutex_setprioceiling — функции считывания и установки предельного значения приоритета мьютекса (REALTIME THREADS).
Синопсис
#include <pthread.h>
int pthread_mutex_getprioceiling (
const pthread_mutex_t *restrict
pthread_mutex_t *restrict
Описание
Функция pthread_mutex_getprioceiling() используется для считывания теку
При неудачном выполнении функции pthread_mutex_setprioceiling() предельное значение приоритета мьютекса не будет изменено.
Возвращаемые значения
При успешном завершении функции pthread_mutex_getprioceiling() и pthread_mutex_setprioceiling() возвращают нулевое значение; в противном случае — код ошибки, обозначающий ее характер.
Ошибки
Функции pthread_mutex_getprioceiling () и pthread_mutex_setprioceiling () могут завершиться неудачно, если:
[EINVAL] приоритет, заданный пара
[EINVAL] значение, заданное пара
[ EPERM] инициатор вызова не и
Эти функции не возвра
Примеры
Отсутствуют.
Замечания по использованию
Отсутствуют.
Логическое обоснование
Отсутствует.
Будущие направления
Отсутствуют.
Смотри также
pthread_mutex_destroy(),pthread_mutex_lock(),
pthread_mutex_timedlock (), то
Последовательность внесения изменений
Функции впервые реализованы в выпуске Issue 5. Включены для согласования с расширением POSIX Threads Extension.
Отмечены как часть группы Realtime Threads Feature Group.
Issue 6
Функции pthread_mutex_getprioceiling () и pthread_mutex_setprioceiling () отмечены как часть опций Threads и Thread Execution Scheduling.