Condividi tramite


Classe initializer_list

Fornisce l'accesso a una matrice di elementi in cui ogni membro è del tipo specificato.

Sintassi

template <class Type>
class initializer_list

Parametri

Type
Tipo di dati degli elementi da archiviare in initializer_list.

Osservazioni:

Un oggetto initializer_list può essere costruito utilizzando un elenco di inizializzatori tra parentesi:

initializer_list<int> i1{ 1, 2, 3, 4 };

Il compilatore trasforma gli elenchi di inizializzatori tra parentesi graffe con elementi omogenei in un oggetto initializer_list ogni volta che la firma della funzione richiede un oggetto initializer_list. Per altre informazioni sull'uso initializer_listdi , vedere Inizializzazione uniforme e delega dei costruttori

Costruttori

Costruttore Descrizione
initializer_list Costruisce un oggetto di tipo initializer_list.

Typedef

Nome tipo Descrizione
value_type Tipo degli elementi contenuti nell'oggetto initializer_list.
reference Tipo che fornisce un riferimento a un elemento archiviato in initializer_list.
const_reference Tipo che fornisce un riferimento costante a un elemento in initializer_list.
size_type Tipo che rappresenta il numero di elementi in initializer_list.
iterator Tipo che fornisce un iteratore per initializer_list.
const_iterator Tipo che fornisce un iteratore costante per initializer_list.

Funzioni membro

Funzione membro Descrizione
begin Restituisce un puntatore al primo elemento in initializer_list.
end Restituisce un puntatore nella posizione successiva dopo l'ultimo elemento in initializer_list.
size Restituisce il numero di elementi nel initializer_list.

Requisiti

Intestazione:<initializer_list>

Spazio dei nomi: std

initializer_list::begin

Restituisce un puntatore al primo elemento in initializer_list.

constexpr const InputIterator* begin() const noexcept;

Valore restituito

Puntatore al primo elemento di initializer_list. Se l'elenco è vuoto, il puntatore sarà lo stesso per l'inizio e la fine dell'elenco.

initializer_list::end

Restituisce un puntatore nella posizione successiva dopo l'ultimo elemento in initializer list.

constexpr const InputIterator* end() const noexcept;

Valore restituito

Puntatore nella posizione successiva dopo l'ultimo elemento nell'elenco. Se l'elenco è vuoto, corrisponde al puntatore al primo elemento dell'elenco.

initializer_list::initializer_list

Costruisce un oggetto di tipo initializer_list.

constexpr initializer_list() noexcept;
initializer_list(const InputIterator First, const InputIterator Last);

Parametri

First
Posizione del primo elemento nell'intervallo di elementi da copiare.

Ultimo
Posizione del primo elemento oltre l'intervallo di elementi da copiare.

Osservazioni:

Un oggetto initializer_list è basato su una matrice di oggetti del tipo specificato. La copia di un oggetto initializer_list crea una seconda istanza di un elenco che punta agli stessi oggetti. Gli oggetti sottostanti non vengono copiati.

Esempio

// initializer_list_class.cpp
// compile with: /EHsc
#include <initializer_list>
#include <iostream>

int main()
{
    using namespace std;
    // Create an empty initializer_list c0
    initializer_list <int> c0;

    // Create an initializer_list c1 with 1 element
    initializer_list <int> c1{ 3 };

    // Create an initializer_list c2 with 5 elements
    initializer_list <int> c2{ 5, 4, 3, 2, 1 };

    // Create a copy, initializer_list c3, of initializer_list c2
    initializer_list <int> c3(c2);

    // Create a initializer_list c4 by copying the range c3[ first,  last)
    const int* c3_ptr = c3.begin();
    c3_ptr++;
    c3_ptr++;
    initializer_list <int> c4(c3.begin(), c3_ptr);

    // Move initializer_list c4 to initializer_list c5
    initializer_list <int> c5(move(c4));

    cout << "c1 =";
    for (auto c : c1)
        cout << " " << c;
    cout << endl;

    cout << "c2 =";
    for (auto c : c2)
        cout << " " << c;
    cout << endl;

    cout << "c3 =";
    for (auto c : c3)
        cout << " " << c;
    cout << endl;

    cout << "c5 =";
    for (auto c : c5)
        cout << " " << c;
    cout << endl;
}
c1 = 3
c2 = 5 4 3 2 1
c3 = 5 4 3 2 1
c5 = 5 4

initializer_list::size

Restituisce il numero di elementi nell'elenco.

constexpr size_t size() const noexcept;

Valore restituito

Numero di elementi contenuti nell'elenco.

Vedi anche

<forward_list>