Namensräume
Varianten

std::try_lock

Aus cppreference.com
< cpp‎ | thread

 
 
Thema Support-Bibliothek
Threads
Original:
Threads
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
thread(C++11)
this_thread Namespace
Original:
this_thread namespace
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
get_id(C++11)
yield(C++11)
sleep_for(C++11)
sleep_until(C++11)
Gegenseitigen Ausschluss
Original:
Mutual exclusion
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
mutex(C++11)
timed_mutex(C++11)
Generische Sperrverwaltung
Original:
Generic lock management
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
lock(C++11)
try_lock(C++11)
defer_lock
try_to_lock
adopt_lock
(C++11)
(C++11)
(C++11)
Zustand Variablen
Original:
Condition variables
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
condition_variable(C++11)
condition_variable_any(C++11)
notify_all_at_thread_exit(C++11)
cv_status(C++11)
Futures
Original:
Futures
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
promise(C++11)
future(C++11)
shared_future(C++11)
packaged_task(C++11)
async(C++11)
 
definiert in Header <mutex>
template<class Lockable1, class Lockable2, class LockableN... >
int try_lock( Lockable1& lock1, Lockable2& lock2, LockableN& lockn... );
(seit C++11)
Versucht jedes der gegebenen Lockable Objekten lock1, lock2, ..., lockn indem try_lock in Reihenfolge, beginnend mit dem ersten .. sperren
Original:
Tries to lock each of the given Lockable objects lock1, lock2, ..., lockn by calling try_lock in order beginning with the first.
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
Wenn ein Aufruf an try_lock fehlschlägt, wird unlock für alle gesperrten Objekte aufgerufen und ein 0 basierende Index des Objekts, zu sperren nicht zurückgegeben wird .
Original:
If a call to try_lock fails, unlock is called for any locked objects and a 0-based index of the object that failed to lock is returned.
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
Wenn ein Aufruf an try_lock führt zu einer Ausnahme wird unlock für alle gesperrten Objekte, bevor erneute Auslösen genannt .
Original:
If a call to try_lock results in an exception, unlock is called for any locked objects before rethrowing.
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.

Inhaltsverzeichnis

[Bearbeiten]Parameter

lock1, lock2, ... , lockn -
Die Lockable Objekte zu sperren
Original:
the Lockable objects to lock
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.

[Bearbeiten]Rückgabewert

-1 auf Erfolg oder 0 basierende Indexwert des Objekts, zu sperren gescheitert .
Original:
-1 on success, or 0-based index value of the object that failed to lock.
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.

[Bearbeiten]Beispiel

Das folgende Beispiel verwendet std::try_lock regelmäßig tally-und Reset-Zähler läuft in separaten Threads .
Original:
The following example uses std::try_lock to periodically tally and reset counters running in separate threads.
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.

#include <mutex>#include <vector>#include <thread>#include <iostream>#include <functional>#include <chrono>   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, constchar*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';}

Possible output:

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

[Bearbeiten]Siehe auch

(C++11)
sperrt angegebenen Mutexe, Blöcke wenn überhaupt verfügbar sind
Original:
locks specified mutexes, blocks if any are unavailable
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.

(Funktions-Template)[edit]
close