std::unique_lock::lock — cppreference.com
<metanoindex/>
<tbody> </tbody>
|
|
(начиная с C++11) | |
Замки соответствующего мьютекса. Эффективно называет mutex()->lock().
Оригинал:
Locks the associated mutex. Effectively calls mutex()->lock().
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
std::system_error создается, если нет связанных мьютекс или, если мьютекс уже заблокирован.
Оригинал:
std::system_error is thrown if there is no associated mutex or if the mutex is already locked.
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Параметры
(Нет)
Возвращаемое значение
(Нет)
Исключения
Любые исключения,
mutex()->lock()Оригинал:
Any exceptions thrown by
mutex()->lock()Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Если нет связанных мьютекс, std::system_error с кодом ошибки std::errc::operation_not_permitted
Оригинал:
If there is no associated mutex, std::system_error with an error code of std::errc::operation_not_permitted
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Если мьютекс уже заблокирован, std::system_error с кодом ошибки std::errc::resource_deadlock_would_occur
Оригинал:
If the mutex is already locked, std::system_error with an error code of std::errc::resource_deadlock_would_occur
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Пример
В следующем примере используется lock повторно приобрести мьютекс, который был разблокирован .
Оригинал:
The following example uses lock to re-acquire a mutex that was unlocked.
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
#include <mutex> #include <thread> #include <iostream> #include <vector> #include <chrono> int main() { int counter = 0; std::mutex counter_mutex; std::vector<std::thread> threads; auto worker_task = [&](int id) { std::unique_lock<std::mutex> lock(counter_mutex); ++counter; std::cout << id << ", initial counter: " << counter << '\n'; lock.unlock(); // don't hold the lock while we simulate an expensive operation std::this_thread::sleep_for(std::chrono::seconds(1)); lock.lock(); ++counter; std::cout << id << ", final counter: " << counter << '\n'; }; for (int i = 0; i < 10; ++i) threads.emplace_back(worker_task, i); for (auto &thread : threads) thread.join(); }
Возможный вывод:
0, initial counter: 1 1, initial counter: 2 2, initial counter: 3 3, initial counter: 4 4, initial counter: 5 5, initial counter: 6 6, initial counter: 7 7, initial counter: 8 8, initial counter: 9 9, initial counter: 10 6, final counter: 11 3, final counter: 12 4, final counter: 13 2, final counter: 14 5, final counter: 15 0, final counter: 16 1, final counter: 17 7, final counter: 18 9, final counter: 19 8, final counter: 20
См. также
пытается заблокировать мьютекс, связанных, возвращается, если мьютекс не доступен Оригинал: tries to lock the associated mutex, returns if the mutex is not available Текст был переведён автоматически используя Переводчик Google. (public функция-элемент) [править] | |
разблокирует соответствующий мьютекс Оригинал: unlocks the associated mutex Текст был переведён автоматически используя Переводчик Google. (public функция-элемент) [править] |