dwww Home | Show directory contents | Find package

.. _parallel_sort_ranges_extension:

parallel_sort ranges interface extension
========================================

.. contents::
    :local:
    :depth: 1

Description
***********

|full_name| implementation extends the `oneapi::tbb::parallel_sort specification <https://spec.oneapi.io/versions/latest/elements/oneTBB/source/algorithms/functions/parallel_sort_func.html>`_
with overloads that takes the container by forwarding reference.


API
***

Header
------

.. code:: cpp

    #include <oneapi/tbb/parallel_sort.h>

Syntax
------

.. code:: cpp

    namespace oneapi {
        namespace tbb {

            template <typename Container>
            void parallel_sort( Container&& c );
            template <typename Container, typename Compare>
            void parallel_sort( Container&& c, const Compare& comp );

        } // namespace tbb
    } // namespace oneapi

Functions
---------

.. cpp:function:: template <typename Container> void parallel_sort( Container&& c );

    Equivalent to ``parallel_sort( std::begin(c), std::end(c), comp )``, where `comp` uses `operator<` to determine relative orderings.

.. cpp:function:: template <typename Container, typename Compare> void parallel_sort( Container&& c, const Compare& comp );

    Equivalent to ``parallel_sort( std::begin(c), std::end(c), comp )``.

Example
-------

This interface may be used for sorting rvalue or constant views:

.. code:: cpp

    #include <array>
    #include <span> // requires C++20
    #include <oneapi/tbb/parallel_sort.h>

    std::span<int> get_span() {
        static std::array<int, 3> arr = {3, 2, 1};
        return std::span<int>(arr);
    }

    int main() {
        tbb::parallel_sort(get_span());
    }

Generated by dwww version 1.15 on Sun Jun 16 04:59:34 CEST 2024.