Initialisatorlisten und Member-Arrays in C 0x
In den frühen Phasen des Erlernens von C 0x kommt es beim Experimentieren häufig zu Syntaxfehlern neue Funktionen. Dieses Problem tritt insbesondere auf, wenn versucht wird, ein Mitgliedsarray innerhalb eines Konstruktors mithilfe einer Initialisierungsliste zu initialisieren.
Beachten Sie den folgenden Code:
<code class="cpp">struct Foo { int const data[2]; Foo(std::initializer_list<int const>& ini) : data(ini) {} }; Foo f = {1,3};</code>
Bei der Kompilierung löst dieser Code den folgenden Fehler aus:
incompatible types in assignment of ‘std::initializer_list<const int>&’ to ‘const int [2]’
Um diesen Fehler zu beheben, umfasst der in der bereitgestellten Antwort empfohlene Ansatz die Verwendung eines variadischen Vorlagenkonstruktors anstelle eines Initialisierungslistenkonstruktors. Die Verwendung dieser Methode stellt die Typkompatibilität sicher und ermöglicht eine flexible Initialisierung von Mitgliedsarrays:
<code class="cpp">struct foo { int x[2]; template <typename... T> foo(T... ts) : x{ts...} {} // curly braces syntax for initializer list }; int main() { foo f1(1, 2); // compiles successfully foo f2{1, 2}; // also compiles foo f3(42); // x[1] is zero-initialized }</code>
Alternativ, wenn die Aufrechterhaltung der Konstanz nicht entscheidend ist, können Sie sich für eine Methode entscheiden, bei der das Array innerhalb des Konstruktorkörpers gefüllt wird:
<code class="cpp">struct foo { int x[2]; foo(std::initializer_list<int> il) { std::copy(il.begin(), il.end(), x); } };</code>
Obwohl dieser Ansatz realisierbar sein mag, opfert er die vom variadic-Vorlagenkonstruktor bereitgestellte Überprüfung der Grenzen zur Kompilierungszeit.
Das obige ist der detaillierte Inhalt vonSo initialisieren Sie Member-Arrays in C 0x-Konstruktoren: Warum schlägt die Verwendung von „std::initializer_list' fehl und wie lässt sich das Problem beheben?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!