std::defer_lock_t, std::try_to_lock_t, std::adopt_lock_t
Материал из cppreference.com
|
|
Эта страница была переведена автоматически с английской версии вики используя Переводчик Google. Перевод может содержать ошибки и странные формулировки. Наведите курсор на текст, чтобы увидеть оригинал. Щёлкните здесь, чтобы увидеть английскую версию этой страницы. (Вы можете помочь в исправлении ошибок и улучшении перевода. Для инструкций перейдите по ссылке.) |
<metanoindex/>
<tbody> </tbody> struct defer_lock_t { }; |
(начиная с C++11) | |
struct try_to_lock_t { }; |
(начиная с C++11) | |
struct adopt_lock_t { }; |
(начиная с C++11) | |
std::defer_lock_t, std::try_to_lock_t и std::adopt_lock_t пустые структуры типов тегов используется для указания блокировки стратегии std::lock_guard и std::unique_lock.Оригинал:
std::defer_lock_t, std::try_to_lock_t and std::adopt_lock_t are empty struct tag types used to specify locking strategy for std::lock_guard and std::unique_lock.Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
| Тип | Effect(s) |
defer_lock_t
|
не приобретают права собственности на мьютекс
Оригинал: do not acquire ownership of the mutex Текст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. |
try_to_lock_t
|
попробуйте приобрести в собственность мьютекса без блокирования
Оригинал: try to acquire ownership of the mutex without blocking Текст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. |
adopt_lock_t
|
Предположим, вызывающий поток уже имеет собственность на мьютекс
Оригинал: assume the calling thread already has ownership of the mutex Текст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. |
Пример
Запустить этот код
#include <mutex>
#include <thread>
struct bank_account {
explicit bank_account(int balance) : balance(balance) {}
int balance;
std::mutex m;
};
void transfer(bank_account &from, bank_account &to, int amount)
{
// attempt to lock both mutexes without deadlock
std::lock(from.m, to.m);
// make sure both already-locked mutexes are unlocked when
// we're done; if we just used the lock_guard without std::lock
// and std::adopt_lock, we might deadlock with other calls to transfer
std::lock_guard lock1(from.m, std::adopt_lock);
std::lock_guard lock2(to.m, std::adopt_lock);
from.balance -= amount;
to.balance += amount;
}
int main()
{
bank_account my_account(100);
bank_account your_account(50);
std::thread t1(transfer, my_account, your_account, 10);
std::thread t2(transfer, your_account, my_account, 5);
t1.join();
t2.join();
}
См. также
(C++11)(C++11)(C++11) |
теговые константы, используемые для определения стратегии блокировки (константа) |
строит объект lock_guard, опционально блокирующий данный мьютекс Оригинал: constructs a lock_guard, optionally locking the given mutex Текст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. (public функция-элемент std::lock_guard)
| |
строит unique_lock, необязательно блокировки поставляется мьютекс Оригинал: constructs a unique_lock, optionally locking the supplied mutex Текст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. (public функция-элемент std::unique_lock)
|