Scroll to navigation

std::initializer_list::initializer_list(3) C++ Standard Libary std::initializer_list::initializer_list(3)

NAME

std::initializer_list::initializer_list - std::initializer_list::initializer_list

Synopsis


initializer_list() noexcept; (since C++11)
(until C++14)
constexpr initializer_list() noexcept; (since C++14)


Constructs an empty initializer list.

Parameters


(none)

Complexity


Constant

Notes


Despite a lack of constructors, it is possible to create non-empty initializer
lists. Instances of std::initializer_list are implicitly constructed when:


* a braced-init-list is used in list-initialization, including function-call list
initialization and assignment expressions (not to be confused with constructor
initializer lists)
* a braced-init-list is bound to auto, including in a ranged for loop

Example

// Run this code


#include <iostream>
#include <initializer_list>


int main()
{
std::initializer_list<int> empty_list;
std::cout << "empty_list.size(): " << empty_list.size() << '\n';


// create initializer lists using list-initialization
std::initializer_list<int> digits {1, 2, 3, 4, 5};
std::cout << "digits.size(): " << digits.size() << '\n';


// special rule for auto means 'fractions' has the
// type std::initializer_list<double>
auto fractions = {3.14159, 2.71828};
std::cout << "fractions.size(): " << fractions.size() << '\n';


// create constexpr initializer list (since C++14)
static constexpr auto ab = {'a', 'b'};
static_assert(ab.size() == 2 and *ab.begin() == 'a');
}

Output:


empty_list.size(): 0
digits.size(): 5
fractions.size(): 2

2024.06.10 http://cppreference.com