STLdoc
STLdocumentation
|
#include <crtdefs.h>
#include <exception>
#include <sal.h>
#include <limits.h>
#include <crtdbg.h>
#include <guiddef.h>
#include <intrin.h>
#include <new>
#include <pplinterface.h>
Go to the source code of this file.
Classes | |
struct | Concurrency::details::_AllocBase |
class | Concurrency::details::_Context |
class | Concurrency::details::_Scheduler |
class | Concurrency::details::_CurrentScheduler |
struct | Concurrency::details::_Subatomic_impl< _Size > |
struct | Concurrency::details::_Subatomic_impl< 4 > |
class | Concurrency::details::_Subatomic< _Ty > |
class | Concurrency::details::_SpinLock |
struct | Concurrency::details::_SpinCount |
class | Concurrency::details::_SpinWait< _YieldCount > |
Implements busy wait with no backoff More... | |
class | Concurrency::details::_ReentrantBlockingLock |
class | Concurrency::details::_ReentrantBlockingLock::_Scoped_lock |
class | Concurrency::details::_ReentrantLock |
class | Concurrency::details::_ReentrantLock::_Scoped_lock |
class | Concurrency::details::_NonReentrantBlockingLock |
class | Concurrency::details::_NonReentrantBlockingLock::_Scoped_lock |
class | Concurrency::details::_ReaderWriterLock |
class | Concurrency::details::_ReaderWriterLock::_Scoped_lock |
class | Concurrency::details::_ReaderWriterLock::_Scoped_lock_read |
class | Concurrency::details::_MallocaArrayHolder< _ElemType > |
class | Concurrency::details::_MallocaListHolder< _ElemType > |
class | Concurrency::details::_MallocaListHolder< _ElemType >::_ElemNodeType |
class | Concurrency::scheduler_resource_allocation_error |
This class describes an exception thrown because of a failure to acquire a critical resource in the Concurrency Runtime. More... | |
class | Concurrency::scheduler_worker_creation_error |
This class describes an exception thrown because of a failure to create a worker execution context in the Concurrency Runtime. More... | |
class | Concurrency::unsupported_os |
This class describes an exception thrown when an unsupported operating system is used. More... | |
class | Concurrency::scheduler_not_attached |
This class describes an exception thrown when an operation is performed which requires a scheduler to be attached to the current context and one is not. More... | |
class | Concurrency::improper_scheduler_attach |
This class describes an exception thrown when the Attach method is called on a Scheduler object which is already attached to the current context. More... | |
class | Concurrency::improper_scheduler_detach |
This class describes an exception thrown when the CurrentScheduler::Detach method is called on a context which has not been attached to any scheduler using the Attach method of a Scheduler object. More... | |
class | Concurrency::improper_scheduler_reference |
This class describes an exception thrown when the Reference method is called on a Scheduler object that is shutting down, from a context that is not part of that scheduler. More... | |
class | Concurrency::default_scheduler_exists |
This class describes an exception thrown when the Scheduler::SetDefaultSchedulerPolicy method is called when a default scheduler already exists within the process. More... | |
class | Concurrency::context_unblock_unbalanced |
This class describes an exception thrown when calls to the Block and Unblock methods of a Context object are not properly paired. More... | |
class | Concurrency::context_self_unblock |
This class describes an exception thrown when the Unblock method of a Context object is called from the same context. This would indicate an attempt by a given context to unblock itself. More... | |
class | Concurrency::missing_wait |
This class describes an exception thrown when there are tasks still scheduled to a task_group or structured_task_group object at the time that object's destructor executes. This exception will never be thrown if the destructor is reached because of a stack unwinding as the result of an exception. More... | |
class | Concurrency::bad_target |
This class describes an exception thrown when a messaging block is given a pointer to a target which is invalid for the operation being performed. More... | |
class | Concurrency::message_not_found |
This class describes an exception thrown when a messaging block is unable to find a requested message. More... | |
class | Concurrency::invalid_link_target |
This class describes an exception thrown when the link_target method of a messaging block is called and the messaging block is unable to link to the target. This can be the result of exceeding the number of links the messaging block is allowed or attempting to link a specific target twice to the same source. More... | |
class | Concurrency::invalid_scheduler_policy_key |
This class describes an exception thrown when an invalid or unknown key is passed to a SchedulerPolicy object constructor, or the SetPolicyValue method of a SchedulerPolicy object is passed a key that must be changed using other means such as the SetConcurrencyLimits method. More... | |
class | Concurrency::invalid_scheduler_policy_value |
This class describes an exception thrown when a policy key of a SchedulerPolicy object is set to an invalid value for that key. More... | |
class | Concurrency::invalid_scheduler_policy_thread_specification |
This class describes an exception thrown when an attempt is made to set the concurrency limits of a SchedulerPolicy object such that the value of the MinConcurrency key is less than the value of the MaxConcurrency key. More... | |
class | Concurrency::nested_scheduler_missing_detach |
This class describes an exception thrown when the Concurrency Runtime detects that you neglected to call the CurrentScheduler::Detach method on a context that attached to a second scheduler using the Attach method of the Scheduler object. More... | |
class | Concurrency::operation_timed_out |
This class describes an exception thrown when an operation has timed out. More... | |
class | Concurrency::invalid_multiple_scheduling |
This class describes an exception thrown when a task_handle object is scheduled multiple times using the run method of a task_group or structured_task_group object without an intervening call to either the wait or run_and_wait methods. More... | |
class | Concurrency::invalid_oversubscribe_operation |
This class describes an exception thrown when the Context::Oversubscribe method is called with the _BeginOversubscription parameter set to false without a prior call to the Context::Oversubscribe method with the _BeginOversubscription parameter set to true . More... | |
class | Concurrency::improper_lock |
This class describes an exception thrown when a lock is acquired improperly. More... | |
class | Concurrency::location |
An abstraction of a physical location on hardware. More... | |
class | Concurrency::critical_section |
A non-reentrant mutex which is explicitly aware of the Concurrency Runtime. More... | |
class | Concurrency::critical_section::scoped_lock |
An exception safe RAII wrapper for a critical_section object. More... | |
class | Concurrency::reader_writer_lock |
A writer-preference queue-based reader-writer lock with local only spinning. The lock grants first in - first out (FIFO) access to writers and starves readers under a continuous load of writers. More... | |
class | Concurrency::reader_writer_lock::scoped_lock |
An exception safe RAII wrapper that can be used to acquire reader_writer_lock lock objects as a writer. More... | |
class | Concurrency::reader_writer_lock::scoped_lock_read |
An exception safe RAII wrapper that can be used to acquire reader_writer_lock lock objects as a reader. More... | |
class | Concurrency::event |
A manual reset event which is explicitly aware of the Concurrency Runtime. More... | |
class | Concurrency::details::_RefCounterBase |
class | Concurrency::details::_NonReentrantPPLLock |
class | Concurrency::details::_NonReentrantPPLLock::_Scoped_lock |
class | Concurrency::details::_ReentrantPPLLock |
class | Concurrency::details::_ReentrantPPLLock::_Scoped_lock |
struct | Concurrency::details::_Chore |
class | Concurrency::details::_UnrealizedChore |
class | Concurrency::details::_TaskCollectionBase |
class | Concurrency::details::_StructuredTaskCollection |
Structured task collections represent groups of work which follow a strictly LIFO ordered paradigm queueing and waiting respectively. They can only be waited on once and can only be used from a single thread of execution. More... | |
class | Concurrency::details::_TaskCollection |
Task collections represent groups of work which step outside the strict structuring of the _StructuredTaskCollection definition. Any groups of work which do not follow LIFO ordering, are waited on multiple times, or are passed between arbitrary threads require utilization of this definition of a task collection. It has additional overhead over the _StructuredTaskCollection. More... | |
class | Concurrency::details::_StackGuard |
RAII wrapper used to maintain and limit ppltask maximum inline schedule depth. This class will keep a reference to the depth slot on current context. More... | |
class | Concurrency::details::_AsyncTaskCollection |
Async Task collections is a thin wrapper over task collection to cater to the execution of asynchronous chores (or tasks defined in ppltasks.h). Specifically, they manage their own lifetime by using reference counts. Scheduling a chore acquires a reference and on completion of its execution the reference is released. More... | |
struct | Concurrency::details::_Beacon_reference |
Internal maintenance structure for beacons. More... | |
class | Concurrency::details::_Cancellation_beacon |
A cancellation beacon is a flag which can be polled in an inlinable fashion using the is_signaled method in lieu of polling on the more expensive non inlinable is_current_task_group_canceling method. More... | |
class | Concurrency::details::_Timer |
struct | Concurrency::details::_CONCRT_TRACE_INFO |
Namespaces | |
Concurrency | |
The Concurrency namespace provides classes and functions that provide access to the Concurrency Runtime, a concurrent programming framework for C++. For more information, see Concurrency Runtime. | |
Concurrency::details | |
Macros | |
#define | _CONCRT_H |
#define | _HRESULT_DEFINED |
#define | _InterlockedIncrementSizeT(_Target) static_cast<size_t>(_InterlockedIncrement64(reinterpret_cast<__int64 volatile *>(_Target))) |
#define | _InterlockedDecrementSizeT(_Target) static_cast<size_t>(_InterlockedDecrement64(reinterpret_cast<__int64 volatile *>(_Target))) |
#define | _InterlockedCompareExchangeSizeT(_Target, _Exchange, _Comparand) |
#define | _CONCRT_ASSERT(x) __assume(x) |
#define | _LISTENTRY_SIZE ((2 * sizeof(void *) + sizeof(_CONCRT_BUFFER) - 1) / sizeof(_CONCRT_BUFFER)) |
#define | _SAFERWLIST_SIZE ((3 * sizeof(void *) + 2 * sizeof(long) + sizeof(_CONCRT_BUFFER) - 1) / sizeof(_CONCRT_BUFFER)) |
#define | _DEBUG_AFFIX "" |
#define | _IDL_DEFAULT 0 |
#define | _LIB_STEM "libconcrt" |
#define | _IDL_AFFIX "" |
Typedefs | |
typedef _SECURITY_ATTRIBUTES * | LPSECURITY_ATTRIBUTES |
typedef _GROUP_AFFINITY * | PGROUP_AFFINITY |
typedef unsigned long | DWORD |
typedef void * | HANDLE |
typedef unsigned __int64 | DWORD_PTR |
typedef unsigned __int64 * | PDWORD_PTR |
typedef void * | _CONCRT_BUFFER |
typedef void(__cdecl * | Concurrency::TaskProc) (void *) |
Concurrency::details contains definitions of support routines in the public namespaces and one or more macros. Users should not directly interact with this internal namespace. More... | |
typedef _SpinWait | Concurrency::details::_SpinWaitBackoffNone |
typedef _SpinWait< 0 > | Concurrency::details::_SpinWaitNoYield |
Functions | |
typedef | _Return_type_success_ (return >=0) long HRESULT |
void | _YieldProcessor () |
_CONCRTIMP void __cdecl | Concurrency::wait (unsigned int _Milliseconds) |
Pauses the current context for a specified amount of time. More... | |
_CONCRTIMP void *__cdecl | Concurrency::Alloc (size_t _NumBytes) |
Allocates a block of memory of the size specified from the Concurrency Runtime Caching Suballocator. More... | |
_CONCRTIMP void __cdecl | Concurrency::Free (_Pre_maybenull_ _Post_invalid_ void *_PAllocation) |
Releases a block of memory previously allocated by the Alloc method to the Concurrency Runtime Caching Suballocator. More... | |
template<class _Ty > | |
void | Concurrency::details::_InternalDeleteHelper (_Ty *_PObject) |
void _CONCRTIMP __cdecl | Concurrency::details::_UnderlyingYield () |
Default method for yielding during a spin wait More... | |
unsigned int _CONCRTIMP __cdecl | Concurrency::details::_GetConcurrency () |
Returns the hardware concurrency available to the Concurrency Runtime, taking into account process affinity, or any restrictions in place because of the set_task_execution_resources method. More... | |
_CONCRTIMP const _CONCRT_TRACE_INFO * | Concurrency::details::_GetConcRTTraceInfo () |
Retrieves a pointer to the internal trace flags and level information for the Concurrency runtime ETW provider. More... | |
void | Concurrency::details::_RegisterConcRTEventTracing () |
Register ConcRT as an ETW Event Provider. More... | |
void | Concurrency::details::_UnregisterConcRTEventTracing () |
Unregister ConcRT as an ETW Event Provider. More... | |
Concurrency::__declspec (deprecated("Concurrency::EnableTracing is a deprecated function.")) _CONCRTIMP HRESULT __cdecl EnableTracing() | |
Enables tracing in the Concurrency Runtime. This function is deprecated because ETW tracing is now on by default. More... | |
Concurrency::__declspec (deprecated("Concurrency::DisableTracing is a deprecated function.")) _CONCRTIMP HRESULT __cdecl DisableTracing() | |
Disables tracing in the Concurrency Runtime. This function is deprecated because ETW tracing is unregistered by default. More... | |
_CONCRTIMP void __cdecl | Concurrency::_Trace_ppl_function (const GUID &_Guid, unsigned char _Level, ConcRT_EventType _Type) |
_CONCRTIMP void __cdecl | Concurrency::_Trace_agents (Agents_EventType _Type, __int64 _AgentId,...) |
Variables | |
const size_t | Concurrency::COOPERATIVE_WAIT_TIMEOUT = SIZE_MAX |
Value indicating that a wait timed out. More... | |
const unsigned int | Concurrency::COOPERATIVE_TIMEOUT_INFINITE = (unsigned int)-1 |
Value indicating that a wait should never time out. More... | |
_CONCRTIMP const GUID | Concurrency::ConcRT_ProviderGuid |
The ETW provider GUID for the Concurrency Runtime. More... | |
_CONCRTIMP const GUID | Concurrency::ConcRTEventGuid |
A category GUID describing ETW events fired by the Concurrency Runtime that are not more specifically described by another category. More... | |
_CONCRTIMP const GUID | Concurrency::SchedulerEventGuid |
A category GUID describing ETW events fired by the Concurrency Runtime that are directly related to scheduler activity. More... | |
_CONCRTIMP const GUID | Concurrency::ScheduleGroupEventGuid |
A category GUID describing ETW events fired by the Concurrency Runtime that are directly related to schedule groups. More... | |
_CONCRTIMP const GUID | Concurrency::ContextEventGuid |
A category GUID describing ETW events fired by the Concurrency Runtime that are directly related to contexts. More... | |
_CONCRTIMP const GUID | Concurrency::ChoreEventGuid |
A category GUID describing ETW events fired by the Concurrency Runtime that are directly related to chores or tasks. More... | |
_CONCRTIMP const GUID | Concurrency::VirtualProcessorEventGuid |
A category GUID describing ETW events fired by the Concurrency Runtime that are directly related to virtual processors. More... | |
_CONCRTIMP const GUID | Concurrency::LockEventGuid |
A category GUID describing ETW events fired by the Concurrency Runtime that are directly related to locks. More... | |
_CONCRTIMP const GUID | Concurrency::ResourceManagerEventGuid |
A category GUID describing ETW events fired by the Concurrency Runtime that are directly related to the resource manager. More... | |
_CONCRTIMP const GUID | Concurrency::PPLParallelInvokeEventGuid |
A category GUID describing ETW events fired by the Concurrency Runtime that are directly related to usage of the parallel_invoke function. More... | |
_CONCRTIMP const GUID | Concurrency::PPLParallelForEventGuid |
A category GUID describing ETW events fired by the Concurrency Runtime that are directly related to usage of the parallel_for function. More... | |
_CONCRTIMP const GUID | Concurrency::PPLParallelForeachEventGuid |
A category GUID describing ETW events fired by the Concurrency Runtime that are directly related to usage of the parallel_for_each function. More... | |
_CONCRTIMP const GUID | Concurrency::AgentEventGuid |
A category GUID ({B9B5B78C-0713-4898-A21A-C67949DCED07}) describing ETW events fired by the Agents library in the Concurrency Runtime. More... | |
#define _CONCRT_ASSERT | ( | x | ) | __assume(x) |
#define _CONCRT_H |
#define _DEBUG_AFFIX "" |
#define _HRESULT_DEFINED |
#define _IDL_AFFIX "" |
#define _IDL_DEFAULT 0 |
#define _InterlockedCompareExchangeSizeT | ( | _Target, | |
_Exchange, | |||
_Comparand | |||
) |
#define _InterlockedDecrementSizeT | ( | _Target | ) | static_cast<size_t>(_InterlockedDecrement64(reinterpret_cast<__int64 volatile *>(_Target))) |
#define _InterlockedIncrementSizeT | ( | _Target | ) | static_cast<size_t>(_InterlockedIncrement64(reinterpret_cast<__int64 volatile *>(_Target))) |
#define _LIB_STEM "libconcrt" |
#define _LISTENTRY_SIZE ((2 * sizeof(void *) + sizeof(_CONCRT_BUFFER) - 1) / sizeof(_CONCRT_BUFFER)) |
#define _SAFERWLIST_SIZE ((3 * sizeof(void *) + 2 * sizeof(long) + sizeof(_CONCRT_BUFFER) - 1) / sizeof(_CONCRT_BUFFER)) |
typedef void* _CONCRT_BUFFER |
typedef unsigned long DWORD |
typedef unsigned __int64 DWORD_PTR |
typedef _SECURITY_ATTRIBUTES* LPSECURITY_ATTRIBUTES |
typedef unsigned __int64 * PDWORD_PTR |
typedef _GROUP_AFFINITY* PGROUP_AFFINITY |
typedef _Return_type_success_ | ( | return >= | 0 | ) |
|
inline |