dwww Home | Show directory contents | Find package

.. _Initializing_and_Terminating_the_Library:

Initializing and Terminating the Library
========================================

|full_name| automatically initializes the task scheduler.
The initialization process is involved when a thread uses task scheduling services the first time,
for example any parallel algorithm, flow graph or task group.
The termination happens when the last such thread exits.

Explicit Library Finalization
*****************************

oneTBB supports an explicit library termination as a preview feature.
The ``oneapi::tbb::finalize`` function called with an instance of class ``oneapi::tbb::task_scheduler_handle`` blocks the calling thread
until all worker threads implicitly created by the library have completed.
If waiting for thread completion is not safe, e.g. may result in a deadlock
or called inside a task, a parallel algorithm, or a flow graph node, the method fails.

If you know how many active ``oneapi::tbb::task_scheduler_handle`` instances exist in the program,
it is recommended to call ``oneapi::tbb::release`` function on all but the last one, then call ``oneapi::tbb::finalize`` for the last instance.

Generated by dwww version 1.15 on Wed May 22 22:31:24 CEST 2024.