std::initializer_list<T>::initializer_list
Материал из cppreference.com
<tbody>
</tbody>
<tbody class="t-dcl-rev ">
</tbody><tbody>
</tbody>
initializer_list() noexcept; |
(начиная с C++11) (до C++14) |
|
constexpr initializer_list() noexcept; |
(начиная с C++14) | |
Создаёт пустой список инициализаторов.
Параметры
(нет)
Сложность
Константная
Примечание
Несмотря на отсутствие конструкторов, можно создавать непустые списки инициализаторов. Экземпляры std::initializer_list создаются неявно, когда:
- список-инициализации-в-скобках используется при инициализации списком, включая инициализацию списком вызовов функций и выражения присваивания (не путать со списком инициализаторов конструктора)
- список-инициализации-в-скобках привязан к
auto, в том числе в диапазоном цикле for
Пример
Запустить этот код
#include <iostream>
#include <initializer_list>
int main()
{
std::initializer_list<int> empty_list;
std::cout << "empty_list.size(): " << empty_list.size() << '\n';
// создать списки инициализаторов, используя инициализацию списком
std::initializer_list<int> digits {1, 2, 3, 4, 5};
std::cout << "digits.size(): " << digits.size() << '\n';
// специальное правило для auto означает, что
// 'fractions' имеет тип std::initializer_list<double>
auto fractions = {3.14159, 2.71828};
std::cout << "fractions.size(): " << fractions.size() << '\n';
// создать список инициализаторов constexpr (начиная с C++14)
static constexpr auto ab = {'a', 'b'};
static_assert(ab.size() == 2 and *ab.begin() == 'a');
}
Вывод:
empty_list.size(): 0
digits.size(): 5
fractions.size(): 2