task_arena¶
[scheduler.task_arena]
A class that represents an explicit, user-managed task scheduler arena.
// Defined in header <tbb/task_arena.h>
namespace tbb {
class task_arena {
public:
static const int automatic = /* implementation-defined */;
static const int not_initialized = /* implementation-defined */;
struct attach {};
task_arena(int max_concurrency = automatic, unsigned reserved_for_masters = 1);
task_arena(const task_arena &s);
explicit task_arena(task_arena::attach);
~task_arena();
void initialize();
void initialize(int max_concurrency, unsigned reserved_for_masters = 1);
void initialize(task_arena::attach);
void terminate();
bool is_active() const;
int max_concurrency() const;
template<typename F> auto execute(F&& f) -> decltype(f());
template<typename F> void enqueue(F&& f);
};
} // namespace tbb
A task_arena
class represents a place where threads may share and execute tasks.
The number of threads that may simultaneously execute tasks in a task_arena
is limited by its concurrency level.
Each user thread that invokes any parallel construction outside an explicit task_arena
uses an implicit
task arena representation object assosiated with the calling thread.
The tasks spawned or enqueued into one arena cannot be executed in another arena.
Note
The task_arena
constructors do not create an internal task arena representation object.
It may already exist in case of the “attaching” constructor, otherwise it is created
by explicit call to task_arena::initialize
or lazily on first use.
Member types and constants¶
-
static const int
automatic
¶ When passed as
max_concurrency
to the specific constructor, arena concurrency will be automatically set based on the hardware configuration.
-
static const int
not_initialized
¶ When returned by a method or function, indicates that there is no active
task_arena
or that thetask_arena
object has not yet been initialized.
-
struct
attach
¶ A tag for constructing a
task_arena
with attach.
Member functions¶
-
task_arena
(int max_concurrency = automatic, unsigned reserved_for_masters = 1)¶ Creates a
task_arena
with a certain concurrency limit (max_concurrency
). Some portion of the limit can be reserved for application threads withreserved_for_masters
. The amount for reservation cannot exceed the limit.Caution
If
max_concurrency
andreserved_for_masters
are explicitly set to be equal and greater than 1, oneTBB worker threads will never join the arena. As a result, the execution guarantee for enqueued tasks is not valid in such arena. Do not usetask_arena::enqueue()
with an arena set to have no worker threads.
-
task_arena
(const task_arena&)¶ Copies settings from another
task_arena
instance.
-
explicit
task_arena
(task_arena::attach)¶ Creates an instance of
task_arena
that is connected to the internal task arena representation currently used by the calling thread. If no such arena exists yet, creates atask_arena
with default parameters.Note
Unlike other constructors, this one automatically initializes the new
task_arena
when connecting to an already existing arena.
-
~task_arena
()¶ Destroys the
task_arena
instance, but the destruction may not be synchronized with any task execution inside thistask_arena
. Which means that an internal task arena representation associated with thistask_arena
instance can be destroyed later. Not thread safe w.r.t. concurrent invocations of other methods.
-
void
initialize
()¶ Performs actual initialization of internal task arena representation.
Note
After the call to
initialize
, the arena parameters are fixed and cannot be changed.
-
void
initialize
(int max_concurrency, unsigned reserved_for_masters = 1)¶ Same as above, but overrides previous arena parameters.
-
void
initialize
(task_arena::attach)¶ If an instance of class
task_arena::attach
is specified as the argument, and there exists an internal task arena representation currently used by the calling thread, the method ignores arena parameters and connectstask_arena
to that internal task arena representation. The method has no effect when called for an already initializedtask_arena
.
-
void
terminate
()¶ Removes the reference to the internal task arena representation without destroying the task_arena object, which can then be re-used. Not thread safe w.r.t. concurrent invocations of other methods.
-
bool
is_active
() const¶ Returns
true
if thetask_arena
has been initialized,false
otherwise.
-
int
max_concurrency
() const¶ Returns the concurrency level of the
task_arena
. Does not require thetask_arena
to be initialized and does not perform initialization.
-
template<F>
voidenqueue
(F &&f)¶ Enqueues a task into the
task_arena
to process the specified functor and immediately returns. TheF
type shall meet the Function Objects requirements from [function.objects] ISO C++ Standard section. The task is scheduled for eventual execution by a worker thread even if no thread ever explicitly waits for the task to complete. If the total number of worker threads is zero, a special additional worker thread is created to execute enqueued tasks.Note
The method does not require the calling thread to join the arena; i.e. any number of threads outside of the arena can submit work to it without blocking.
Caution
There is no guarantee that tasks enqueued into an arena execute concurrently with respect to any other tasks there.
Caution
An exception thrown and not caught in the functor results in undefined behavior.
-
template<F> auto execute(F&& f) -> decltype(f())
Executes the specified functor in the
task_arena
and returns the value returned by the functor. TheF
type shall meet the Function Objects requirements from [function.objects] ISO C++ Standard section.The calling thread joins the
task_arena
if possible, and executes the functor. Upon return it restores the previous task scheduler state and floating-point settings.If joining the
task_arena
is not possible, the call wraps the functor into a task, enqueues it into the arena, waits using an OS kernel synchronization object for another opportunity to join, and finishes after the task completion.An exception thrown in the functor will be captured and re-thrown from
execute
.Note
Any number of threads outside of the arena can submit work to the arena and be blocked. However, only the maximal number of threads specified for the arena can participate in executing the work.
See also: