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
;
|
(seit C++11)
(constexpr seit C++14) |
|
Konstruiert eine leere Initialisierungsliste.
Inhaltsverzeichnis |
Parameter
(keine)
Komplexität
Konstante
Hinweise
Trotz des Fehlens von Konstruktoren ist es möglich, nicht-leere Initialisierungslisten zu erstellen. Instanzen von
std::initializer_list
werden implizit konstruiert, wenn:
- ein braced-init-list wird in der Listeninitialisierung verwendet, einschließlich Funktionsaufruf-Listeninitialisierung und Zuweisungsausdrücken (nicht zu verwechseln mit Konstruktor-Initialisierungslisten )
- eine braced-init-list wird an auto gebunden, einschließlich in einer Bereichs-for-Schleife
Beispiel
Diesen Code ausführen
#include <initializer_list> #include <iostream> int main() { std::initializer_list<int> empty_list; std::cout << "empty_list.size(): " << empty_list.size() << '\n'; // Initialisierungslisten mittels Listeninitialisierung erstellen std::initializer_list<int> digits{1, 2, 3, 4, 5}; std::cout << "digits.size(): " << digits.size() << '\n'; // Spezialregel für auto bedeutet, dass 'fractions' den // Typ std::initializer_list<double> hat auto fractions = {3.14159, 2.71828}; std::cout << "fractions.size(): " << fractions.size() << '\n'; // Konstante Initialisierungsliste erstellen (seit C++14) static constexpr auto ab = {'a', 'b'}; static_assert(ab.size() == 2 and *ab.begin() == 'a'); }
Ausgabe:
empty_list.size(): 0 digits.size(): 5 fractions.size(): 2