Namespaces
Variants
Views
Actions

Difference between revisions of "cpp/thread"

From cppreference.com
< cpp
m (-typo)
(future_error belongs here too)
Line 65: Line 65:
 
{{dcl list template | cpp/thread/dcl list async}}
 
{{dcl list template | cpp/thread/dcl list async}}
 
{{dcl list template | cpp/thread/dcl list launch}}
 
{{dcl list template | cpp/thread/dcl list launch}}
 +
{{dcl list class | cpp/thread/future_error | notes={{mark c++11}} | reports an error related to futures or promises }}
 
{{dcl list fun | cpp/thread/future_category  | notes={{mark c++11}} | identifies the future error category}}
 
{{dcl list fun | cpp/thread/future_category  | notes={{mark c++11}} | identifies the future error category}}
{{dcl list enum | cpp/thread/future_errc  | notes={{mark c++11}} | the future error codes}}
+
{{dcl list enum | cpp/thread/future_errc  | notes={{mark c++11}} | identifies the future error codes}}
 
{{dcl list end}}
 
{{dcl list end}}

Revision as of 05:32, 6 June 2012

Template:cpp/thread/sidebar

Contents

Threads

Threads enable the program to execute across several processor cores.

Template:cpp/thread/dcl list threadTemplate:cpp/thread/dcl list yieldTemplate:cpp/thread/dcl list get idTemplate:cpp/thread/dcl list sleep forTemplate:cpp/thread/dcl list sleep until
Defined in header <thread>
Functions managing the current thread
Defined in namespace this_thread

Mutual exclusion

Mutual exclusion algorithms restrict access to a shared resource so that only one thread can access it at a time. This allows to avoid data races and to implement synchronization between threads.

Template:cpp/thread/dcl list mutexTemplate:cpp/thread/dcl list timed mutexTemplate:cpp/thread/dcl list recursive mutexTemplate:cpp/thread/dcl list recursive timed mutexTemplate:cpp/thread/dcl list lock guardTemplate:cpp/thread/dcl list unique lockTemplate:cpp/thread/dcl list lock tag tTemplate:cpp/thread/dcl list lock tagTemplate:cpp/thread/dcl list try lockTemplate:cpp/thread/dcl list lockTemplate:cpp/thread/dcl list once flagTemplate:cpp/thread/dcl list call once
Defined in header <mutex>
Generic mutex management
Generic locking algorithms
Call once

Condition variables

A condition variable is a synchronization primitive which implements a list of threads that are waiting until another thread notifies one or all of the waiting threads that they may proceed, until a timeout expires, or until a spurious wakeup occurs. A condition variable is always associated with a mutex.

provides a condition variable assocaited with std::unique_lock
(class)
provides a condition variable associated with any lock type
(class)
schedules a call to notify_all to be invoked when this thread exits
(function)
(C++11)
lists the possible results of timed waits on condition variables
(enum)

Futures

The standard library provides facilities to obtain values that are returned and to catch exceptions that are thrown by asynchronous tasks, that is, by the functions launched on threads. These values are communicated in a shared state, in which the asynchronous task may write its return value or store an exception, and which may be examined, waited for, and otherwise manipulated by other threads that hold instances of std::future or std::shared_future that reference that shared state.

Template:cpp/thread/dcl list promiseTemplate:cpp/thread/dcl list packaged taskTemplate:cpp/thread/dcl list futureTemplate:cpp/thread/dcl list shared futureTemplate:cpp/thread/dcl list asyncTemplate:cpp/thread/dcl list launch
Defined in header <future>
reports an error related to futures or promises
(class)
identifies the future error category
(function)
identifies the future error codes
(enum)