std::unique_lock
Материал из cppreference.com
![]() |
Эта страница была переведена автоматически с английской версии вики используя Переводчик Google. Перевод может содержать ошибки и странные формулировки. Наведите курсор на текст, чтобы увидеть оригинал. Щёлкните здесь, чтобы увидеть английскую версию этой страницы. (Вы можете помочь в исправлении ошибок и улучшении перевода. Для инструкций перейдите по ссылке.) |
Определено в заголовочном файле <mutex>
|
||
template< class Mutex > class unique_lock; |
(начиная с C++11) | |
Класс unique_lock является общего назначения мьютекс собственности оболочки позволяет отложенные замок, своевременное замок, рекурсивные замок, блокировка передачи собственности, и использовать с переменными условия.
Оригинал:
The class unique_lock is a general-purpose mutex ownership wrapper allowing deferred locking, timed locking, recursive locking, transfer of lock ownership, and use with condition variables.
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
unique_lock
класса, не скопировать, но она подвижна. Поставляемых Mutex
типа осуществляют BasicLockable
концепции.Оригинал:
The
unique_lock
class is non-copyable, but it is movable. The supplied Mutex
type shall implement the BasicLockable
concept.Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Содержание |
[править] Типы-члены
Тип | Definition |
mutex_type
|
Mutex |
[править] Функции-члены
строит unique_lock , необязательно блокировки поставляется мьютекс Оригинал: constructs a unique_lock , optionally locking the supplied mutex Текст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. (public функция-элемент) | |
разблокирует соответствующий мьютекс, если они принадлежат Оригинал: unlocks the associated mutex, if owned Текст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инс��рукций щёлкните сюда. (public функция-элемент) | |
разблокирует мьютекс, если они принадлежат, а также приобретает право собственности другому Оригинал: unlocks the mutex, if owned, and acquires ownership of another Текст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. (public функция-элемент) | |
Оригинал: Locking Текст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. | |
locks the associated mutex (public функция-элемент) | |
пытается заблокировать мьютекс, связанных, возвращается, если мьютекс не доступен Оригинал: tries to lock the associated mutex, returns if the mutex is not available Текст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. (public функция-элемент) | |
Попытки заблокировать соответствующие TimedLockable мьютекс, возвращается, если мьютекс был недоступен для заданного времениОригинал: attempts to lock the associated TimedLockable mutex, returns if the mutex has been unavailable for the specified time durationТекст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. (public функция-элемент) | |
пытается заблокировать мьютекс связанных TimedLockable , возвращается, если мьютекс был недоступен до указанного момента времени была достигнута Оригинал: tries to lock the associated TimedLockable mutex, returns if the mutex has been unavailable until specified time point has been reached Текст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. (public функция-элемент) | |
разблокирует соответствующий мьютекс Оригинал: unlocks the associated mutex Текст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. (public функция-элемент) | |
Модификаторы | |
свопы состояние с другой std::unique_lock Оригинал: swaps state with another std::unique_lock Текст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. (public функция-элемент) | |
дистанцируется связанных мьютекса без разблокировки он Оригинал: disassociates the associated mutex without unlocking it Текст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. (public функция-элемент) | |
Наблюдатели | |
возвращает указатель на соответствующий мьютекс Оригинал: returns a pointer to the associated mutex Текст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. (public функци��-элемент) | |
Тесты ли замок принадлежит связанных мьютекс Оригинал: tests whether the lock owns its associated mutex Текст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. (public функция-элемент) | |
Тесты ли замок принадлежит связанных мьютекс Оригинал: tests whether the lock owns its associated mutex Текст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. (public функция-элемент) |
[править] Функции, не являющиеся членами
Специализация std::swap для unique_lock Оригинал: specialization of std::swap for unique_lock Текст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. (шаблон функции) |
[править] Пример
Запустить этот код
#include <mutex> #include <thread> #include <chrono> struct Box { explicit Box(int num) : num_things{num} {} int num_things; std::mutex m; }; void transfer(Box &from, Box &to, int num) { // don't actually take the locks yet std::unique_lock<std::mutex> lock1(from.m, std::defer_lock); std::unique_lock<std::mutex> lock2(to.m, std::defer_lock); // lock both unique_locks without deadlock std::lock(lock1, lock2); from.num_things -= num; to.num_things += num; lock1.unlock(); lock2.unlock(); } int main() { Box acc1(100); Box acc2(50); std::thread t1(transfer, std::ref(acc1), std::ref(acc2), 10); std::thread t2(transfer, std::ref(acc2), std::ref(acc1), 5); t1.join(); t2.join(); }