<array> – funkce

Záhlaví <pole> obsahuje dvě nečlenné funkce a swapget , které pracují s objekty pole.

get
vyměnit

get

Vrátí odkaz na zadaný prvek pole.

template <int Index, class T, size_t N>
constexpr T& get(array<T, N>& arr) noexcept;

template <int Index, class T, size_t N>
constexpr const T& get(const array<T, N>& arr) noexcept;

template <int Index, class T, size_t N>
constexpr T&& get(array<T, N>&& arr) noexcept;

Parametry

Index
Posun prvku.

T
Typ prvku

N
Počet prvků v poli.

Arr
Pole, ze které chcete vybrat.

Příklad

#include <array>
#include <iostream>

using namespace std;

typedef array<int, 4> MyArray;

int main()
{
    MyArray c0 { 0, 1, 2, 3 };

    // display contents " 0 1 2 3"
    for (const auto& e : c0)
    {
        cout << " " << e;
    }
    cout << endl;

    // display odd elements " 1 3"
    cout << " " << get<1>(c0);
    cout << " " << get<3>(c0) << endl;
}
0 1 2 3
1 3

swap

Specializace std::swap šablony, která není členem, prohodí dva objekty pole .

template <class Ty, std::size_t N>
void swap(array<Ty, N>& left, array<Ty, N>& right);

Parametry

Ty
Typ prvku

N
Velikost pole.

Vlevo
První pole, které se má prohodit.

Vpravo
Druhé pole, které se má prohodit.

Poznámky

Funkce šablony left.swap(right)se spustí .

Příklad

// std__array__swap.cpp
// compile with: /EHsc
#include <array>
#include <iostream>

typedef std::array<int, 4> Myarray;
int main()
{
    Myarray c0 = { 0, 1, 2, 3 };

    // display contents " 0 1 2 3"
    for (Myarray::const_iterator it = c0.begin();
        it != c0.end(); ++it)
        std::cout << " " << *it;
    std::cout << std::endl;

    Myarray c1 = { 4, 5, 6, 7 };
    c0.swap(c1);

    // display swapped contents " 4 5 6 7"
    for (Myarray::const_iterator it = c0.begin();
        it != c0.end(); ++it)
        std::cout << " " << *it;
    std::cout << std::endl;

    swap(c0, c1);

    // display swapped contents " 0 1 2 3"
    for (Myarray::const_iterator it = c0.begin();
        it != c0.end(); ++it)
        std::cout << " " << *it;
    std::cout << std::endl;

    return (0);
}
0 1 2 3
4 5 6 7
0 1 2 3

Viz také

<pole>