std::initializer_list<T>:: initializer_list
From cppreference.net
<
cpp
|
utility
|
initializer list
C++
Utilities library
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
std::initializer_list
| Member functions | ||||
|
initializer_list::initializer_list
|
||||
| Capacity | ||||
| Iterators | ||||
| Non-member functions | ||||
|
initializer_list
(
)
noexcept
;
|
(desde C++11)
(constexpr desde C++14) |
|
Construye una lista de inicializadores vacía.
Contenidos |
Parámetros
(ninguno)
Complejidad
Constante
Notas
A pesar de la falta de constructores, es posible crear listas de inicializadores no vacías. Las instancias de
std::initializer_list
se construyen implícitamente cuando:
- un braced-init-list se utiliza en list-initialization , incluyendo la inicialización de lista en llamadas a función y expresiones de asignación (no debe confundirse con constructor initializer lists )
- un braced-init-list se vincula a auto , incluso en un ranged for loop
Ejemplo
Ejecutar este código
#include <initializer_list> #include <iostream> int main() { std::initializer_list<int> empty_list; std::cout << "empty_list.size(): " << empty_list.size() << '\n'; // crear listas de inicialización usando inicialización de lista std::initializer_list<int> digits{1, 2, 3, 4, 5}; std::cout << "digits.size(): " << digits.size() << '\n'; // regla especial para auto significa que 'fractions' tiene el // tipo std::initializer_list<double> auto fractions = {3.14159, 2.71828}; std::cout << "fractions.size(): " << fractions.size() << '\n'; // crear lista de inicialización constexpr (desde C++14) static constexpr auto ab = {'a', 'b'}; static_assert(ab.size() == 2 and *ab.begin() == 'a'); }
Salida:
empty_list.size(): 0 digits.size(): 5 fractions.size(): 2