QNX/UNIX: Анатомия параллелизма
QNX/UNIX: Анатомия параллелизма читать книгу онлайн
Книга адресована программистам, работающим в самых разнообразных ОС UNIX. Авторы предлагают шире взглянуть на возможности параллельной организации вычислительного процесса в традиционном программировании. Особый акцент делается на потоках (threads), а именно на тех возможностях и сложностях, которые были привнесены в технику параллельных вычислений этой относительно новой парадигмой программирования. На примерах реальных кодов показываются приемы и преимущества параллельной организации вычислительного процесса. Некоторые из результатов испытаний тестовых примеров будут большим сюрпризом даже для самых бывалых программистов. Тем не менее излагаемые техники вполне доступны и начинающим программистам: для изучения материала требуется базовое знание языка программирования C/C++ и некоторое понимание «устройства» современных многозадачных ОС UNIX.
В качестве «испытательной площадки» для тестовых фрагментов выбрана ОСРВ QNX, что позволило с единой точки зрения взглянуть как на специфические механизмы микроядерной архитектуры QNX, так и на универсальные механизмы POSIX. В этом качестве книга может быть интересна и тем, кто не использует (и не планирует никогда использовать) ОС QNX: программистам в Linux, FreeBSD, NetBSD, Solaris и других традиционных ОС UNIX.
Внимание! Книга может содержать контент только для совершеннолетних. Для несовершеннолетних чтение данного контента СТРОГО ЗАПРЕЩЕНО! Если в книге присутствует наличие пропаганды ЛГБТ и другого, запрещенного контента - просьба написать на почту [email protected] для удаления материала
Захват мьютекса
Захват мьютекса может производиться тремя разными функциями, в основе которых лежит функция из native QNX API
SyncMutexLock()
int pthread_mutex_lock(pthread_mutex_t* mutex);Функция захватывает мьютекс, на который ссылается
mutexpthread_mutex_lock()pthread_mutex_lock()pthread_mutex_lock()EDEADLKФункция
pthread_mutex_lock()
EAGAIN
EDEADLK
EINVALmutex
int pthread_mutex_trylock(pthread_mutex_t* mutex);Функция проверяет, свободен ли мьютекс
mutexEBUSYВозвращаемые значения:
EOK
EAGAIN
EBUSYmutex
EINVALmutex.
#include <pthread.h>
#include <time.h>
int pthread_mutex_timedlock(pthread_mutex_t* mutex,
const struct timespec* abs_timeout);Функция проверяет, свободен ли мьютекс (
mutexabs_timeoutНаступление времени определяется по часам
REALTIME_CLOCKabs_timeout<time.h>Если мьютекс создан с атрибутом протокола
PRIO_INHERITВозвращаемые значения:
EOK
EAGAIN
EDEADLK
EINVALprotocolPTHREAD_PRIO_PROTECTabs_timeoutmutex
ETIMEDOUTОсвобождение мьютекса
int pthread_mutex_unlock(pthread_mutex_t* mutex);Функция
pthread_mutex_unlock()mutexДля мьютексов, разрешающих рекурсивный захват, функция освобождения должна вызываться столько же раз, сколько и функция захвата.
Возвращаемые значения:
EOK
EINVALmutex
EPERMРазрушение объекта мьютекс
int pthread_mutex_destroy(pthread_mutex_t* mutex);Вызов разрушает объект мьютекс, на который указывает переменная
mutexpthread_mutex_init()Возвращаемые значения:
EOK
EBUSY-
EINVALmutexОперации, не поддерживаемые POSIX
В native QNX API есть ряд функций работы с мьютексом, которые не определены POSIX-стандартом, однако они могут оказаться весьма полезными. Поскольку тип POSIX-мьютекса порождается от
sync_t
