Энтони Уильямс - Параллельное программирование на С++ в действии. Практика разработки многопоточных программ
- Название:Параллельное программирование на С++ в действии. Практика разработки многопоточных программ
- Автор:
- Жанр:
- Издательство:ДМК Пресс
- Год:2012
- Город:Москва
- ISBN:978-5-94074-448-1
- Рейтинг:
- Избранное:Добавить в избранное
-
Отзывы:
-
Ваша оценка:
Энтони Уильямс - Параллельное программирование на С++ в действии. Практика разработки многопоточных программ краткое содержание
Книга «Параллельное программирование на С++ в действии» не предполагает предварительных знаний в этой области. Вдумчиво читая ее, вы научитесь писать надежные и элегантные многопоточные программы на С++11. Вы узнаете о том, что такое потоковая модель памяти, и о том, какие средства поддержки многопоточности, в том числе запуска и синхронизации потоков, имеются в стандартной библиотеке. Попутно вы познакомитесь с различными нетривиальными проблемами программирования в условиях параллелизма.
Параллельное программирование на С++ в действии. Практика разработки многопоточных программ - читать онлайн бесплатно полную версию (весь текст целиком)
Интервал:
Закладка:
Обменивает владение ассоциированными блокировками мьютекса между двумя объектами std::unique_lock
.
Объявление
void swap(unique_lock& lhs, unique_lock& rhs) noexcept;
Результат
lhs.swap(rhs)
Исключения
Нет.
STD::UNIQUE_LOCK::LOCK
, ФУНКЦИЯ-ЧЛЕН
Захватывает мьютекс, ассоциированный с *this
.
Объявление
void lock();
Предусловия
this->mutex() != NULL
, this->owns_lock() == false
.
Результат
Вызывает this->mutex()->lock()
.
Исключения
Любое исключение, возбужденное this->mutex()->lock()
. Исключение типа std::system_error
с кодом ошибки std::errc::operation_not_permitted
, если this->mutex() == NULL
. Исключение типа std::system_error
с кодом ошибки std::errc::resource_deadlock_would_occur
, если this->owns_lock() == true
в момент вызова.
Постусловия
this->owns_lock() == true
.
STD::UNIQUE_LOCK::TRY_LOCK
, ФУНКЦИЯ-ЧЛЕН
Пытается захватить мьютекс, ассоциированный с *this
.
Объявление
bool try_lock();
Предусловия
Тип Mutex
, которым конкретизируется шаблон std::unique_lock
, должен удовлетворять требованиям концепции Lockable
. this->mutex() != NULL
, this->owns_lock() == false
.
Результат
Вызывает this->mutex ()->try_lock()
.
Возвращаемое значение
true
, если вызов this->mutex()->try_lock()
вернул true
, иначе false
.
Исключения
Любое исключение, возбужденное this->mutex()->try_lock()
. Исключение типа std::system_error
с кодом ошибки std::errc::operation_not_permitted
, если this->mutex() == NULL
. Исключение типа std::system_error
с кодом ошибки std::errc::resource_deadlock_would_occur
, если this->owns_lock() == true
в момент вызова.
Постусловия
Если функция возвращает true
, то this->owns_lock() == true
, иначе this->owns_lock() == false
.
STD::UNIQUE_LOCK::UNLOCK
, ФУНКЦИЯ-ЧЛЕН
Освобождает мьютекс, ассоциированный с *this
.
Объявление
void unlock();
Предусловия
this->mutex() != NULL
, this->owns_lock() == true
.
Результат
Вызывает this->mutex()->unlock()
.
Исключения
Любое исключение, возбужденное this->mutex()->unlock()
. Исключение типа std::system_error
с кодом ошибки std::errc::operation_not_permitted
, если this->owns_lock() == false
в момент вызова.
Постусловия
this->owns_lock() == false
.
STD::UNIQUE_LOCK::TRY_LOCK_FOR
, ФУНКЦИЯ-ЧЛЕН
Пытается захватить мьютекс, ассоциированный с *this
, в течение указанного времени.
Объявление
template
bool try_lock_for(
std::chrono::duration const& relative_time);
Предусловия
Тип Mutex
, которым конкретизируется шаблон std::unique_lock
, должен удовлетворять требованиям концепции TimedLockable
. this->mutex() != NULL
, this->owns_lock() == false
.
Результат
Вызывает this->mutex ()->try_lock_for(relative_time)
.
Возвращаемое значение
true
, если вызов this->mutex()->try_lock_for()
вернул true
, иначе false
.
Исключения
Любое исключение, возбужденное this->mutex()->try_lock_for()
. Исключение типа std::system_error
с кодом ошибки std::errc::operation_not_permitted
, если this->mutex() == NULL
. Исключение типа std::system_error
с кодом ошибки std::errc::resource_deadlock_would_occur
, если this->owns_lock() == true
в момент вызова.
Постусловия
Если функция вернула true
, то this->owns_lock() == true
, иначе this->owns_lock() == false
.
STD::UNIQUE_LOCK::TRY_LOCK_UNTIL
, ФУНКЦИЯ-ЧЛЕН
Пытается захватить мьютекс, ассоциированный с *this
, в течение указанного времени.
Объявление
template
bool try_lock_until(
std::chrono::time_point const& absolute_time);
Предусловия
Тип Mutex
, которым конкретизируется шаблон std::unique_lock
, должен удовлетворять требованиям концепции TimedLockable
. this->mutex() != NULL
, this->owns_lock() == false
.
Результат
Вызывает this->mutex()->try_lock_until(absolute_time)
.
Возвращаемое значение
true
, если вызов this->mutex()->try_lock_until()
вернул true
, иначе false
.
Исключения
Любое исключение, возбужденное this->mutex()->try_lock_until()
. Исключение типа std::system_error
с кодом ошибки std::errc::operation_not_permitted
, если this->mutex() == NULL
. Исключение типа std::system_error
с кодом ошибки std::errc::resource_deadlock_would_occur
, если this->owns_lock() == true
в момент вызова.
Постусловия
Если функция вернула true
, то this->owns_lock() == true
, иначе this->owns_lock() == false
.
STD::UNIQUE_LOCK::OPERATOR BOOL
, ФУНКЦИЯ-ЧЛЕН
Проверяет, владеет ли *this
блокировкой мьютекса.
Объявление
explicit operator bool() const noexcept;
Возвращаемое значение this->owns_lock()
. Исключения
Нет.
Примечание. Это оператор явного преобразования, поэтому он вызывается неявно только в контекстах, где результат используется как булевское значение, а не тогда, когда результат трактуется как целое, равное 0 или 1.
STD::UNIQUE_LOCK::OWNS_LOCK
, ФУНКЦИЯ-ЧЛЕН
Проверяет, владеет ли *this
блокировкой мьютекса.
Объявление
bool owns_lock() const noexcept;
Возвращаемое значение
true
, если *this
владеет блокировкой мьютекса, иначе false
.
Исключения
Нет.
STD::UNIQUE_LOCK::MUTEX
, ФУНКЦИЯ-ЧЛЕН
Возвращает мьютекс, ассоциированный с *this
, если таковой имеется.
Объявление
mutex_type* mutex() const noexcept;
Возвращаемое значение
Указатель на мьютекс, ассоциированный с *this
, если таковой имеется, иначе NULL
.
Исключения
Нет.
STD::UNIQUE_LOCK::RELEASE
, ФУНКЦИЯ-ЧЛЕН
Возвращает мьютекс, ассоциированный с *this
, если таковой имеется, и разрывает эту ассоциацию.
Объявление
mutex_type* release() noexcept;
Результат
Разрывает ассоциацию мьютекса с *this
, не освобождая блокировку.
Возвращаемое значение
Указатель на мьютекс, ассоциированный с *this
, если таковой имеется, иначе NULL
.
Постусловия
this->mutex() == NULL
, this->owns_lock() == false.
Исключения
Нет.
Примечание. Если this->owns_lock()
вернула бы до этого обращения true
, то с этого момента за освобождение мьютекса отвечает вызывающая программа.
D.5.7. Шаблон функции std::lock
Шаблон функции std::lock
предоставляет возможность захватить сразу несколько мьютексов, не опасаясь возникновения взаимоблокировки из-за несогласованного порядка захвата.
Объявление
template
void lock(LockableType1& m1, LockableType2& m2...);
Предусловия
Типы параметров LockableType1
, LockableType2
, … должны удовлетворять требованиям концепции Lockable
.
Интервал:
Закладка: