std:: try_lock
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
헤더 파일에 정의됨
<mutex>
|
||
|
template
<
class
Lockable1,
class
Lockable2,
class
...
LockableN
>
int try_lock ( Lockable1 & lock1, Lockable2 & lock2, LockableN & ... lockn ) ; |
(C++11 이후) | |
주어진
Lockable
객체들
lock1
,
lock2
,
...
,
lockn
을 첫 번째부터 순서대로
try_lock
을 호출하여 잠그려고 시도합니다.
try_lock
호출이 실패할 경우, 더 이상의
try_lock
호출은 수행되지 않으며,
잠긴 객체들에 대해
unlock
이 호출되고 잠금에 실패한 객체의
0
기반 인덱스가 반환됩니다.
try_lock
호출이 예외를 발생시키는 경우,
다시 던지기 전에 잠긴 모든 객체에 대해
unlock
이 호출됩니다.
목차 |
매개변수
| lock1, lock2, ..., lockn | - | 잠글 Lockable 객체들 |
반환값
- 1 성공 시, 또는 0 -기반 잠금 실패 객체의 인덱스 값.
예제
다음 예제는 별도의 스레드에서 실행되는 카운터를 주기적으로 집계하고 재설정하기 위해
std::try_lock
을 사용합니다.
#include <chrono> #include <functional> #include <iostream> #include <mutex> #include <thread> #include <vector> int main() { int foo_count = 0; std::mutex foo_count_mutex; int bar_count = 0; std::mutex bar_count_mutex; int overall_count = 0; bool done = false; std::mutex done_mutex; auto increment = [](int& counter, std::mutex& m, const char* desc) { for (int i = 0; i < 10; ++i) { std::unique_lock<std::mutex> lock(m); ++counter; std::cout << desc << ": " << counter << '\n'; lock.unlock(); std::this_thread::sleep_for(std::chrono::seconds(1)); } }; std::thread increment_foo(increment, std::ref(foo_count), std::ref(foo_count_mutex), "foo"); std::thread increment_bar(increment, std::ref(bar_count), std::ref(bar_count_mutex), "bar"); std::thread update_overall([&]() { done_mutex.lock(); while (!done) { done_mutex.unlock(); int result = std::try_lock(foo_count_mutex, bar_count_mutex); if (result == -1) { overall_count += foo_count + bar_count; foo_count = 0; bar_count = 0; std::cout << "overall: " << overall_count << '\n'; foo_count_mutex.unlock(); bar_count_mutex.unlock(); } std::this_thread::sleep_for(std::chrono::seconds(2)); done_mutex.lock(); } done_mutex.unlock(); }); increment_foo.join(); increment_bar.join(); done_mutex.lock(); done = true; done_mutex.unlock(); update_overall.join(); std::cout << "Done processing\n" << "foo: " << foo_count << '\n' << "bar: " << bar_count << '\n' << "overall: " << overall_count << '\n'; }
가능한 출력:
bar: 1 foo: 1 foo: 2 bar: 2 foo: 3 overall: 5 bar: 1 foo: 1 bar: 2 foo: 2 bar: 3 overall: 10 bar: 1 foo: 1 bar: 2 foo: 2 overall: 14 bar: 1 foo: 1 bar: 2 overall: 17 foo: 1 bar: 1 foo: 2 overall: 20 Done processing foo: 0 bar: 0 overall: 20
참고 항목
|
(C++11)
|
지정된 뮤텍스들을 잠금, 사용 불가능한 경우 블록
(함수 템플릿) |