Пространства имён
Варианты
Действия

std::defer_lock_t, std::try_to_lock_t, std::adopt_lock_t

Материал из cppreference.com
< cpp‎ | thread

 
 
Библиотека поддержки конкуренции
Ветви
(C++11)
(C++20)
(C++20)
Пространство имён this_thread
(C++11)
(C++11)
(C++11)
Атомарные типы
(C++11)
(C++20)
Инициализация атомарных типов
(C++11)(устарело в C++20)
(C++11)(устарело в C++20)
(C++11)(устарело в C++20)
Функции освобождения для атомарных операций
Функции освобождения для атомарных флагов
Упорядочивание памяти
Взаимное исключение
(C++11)
Общее управлени�� блокировкой
(C++11)
defer_lock_ttry_to_lock_tadopt_lock_t
(C++11)(C++11)(C++11)
(C++11)
(C++11)
(C++11)(C++11)(C++11)
(C++11)
(C++11)
Условные переменные
(C++11)
Семафоры
Защёлки и барьеры
(C++20)
(C++20)
Фьючерсы
(C++11)
(C++11)
(C++11)
(C++11)
 
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();
}

[править] См. также

теговые константы, используемые для определения стратегии блокировки
(константа) [править]
строит объект 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) [править]