Designierte Initialisierer und Aggregate in C 20
In C 20 bieten designierte Initialisierer eine prägnante Möglichkeit, Aggregattypen durch explizite Angabe des Mitglieds zu initialisieren initialisiert werden. Diese Syntax weist jedoch Einschränkungen auf, wenn es um die Initialisierung geerbter Klassen geht.
Beachten Sie den folgenden Codeausschnitt:
<code class="cpp">struct Person { std::string name; std::string surname; unsigned age; }; struct Employee : Person { unsigned salary; };</code>
Sowohl Person als auch Employee sind Aggregate, aber der folgende Versuch, Employee zu initialisieren, wird verwendet designierte Initialisierer schlagen fehl:
<code class="cpp">Employee e1{.name{"John"}, .surname{"Wick"}, .age{40}, .salary{50000}};</code>
Dies liegt daran, dass der C-Standard angibt, dass designierte Initialisierer nur zum Initialisieren direkter nicht statischer Datenelemente einer Klasse verwendet werden können. Im obigen Beispiel ist das Gehalt ein Mitglied der abgeleiteten Klasse Employee und nicht der direkten Basisklasse Person, daher ist eine designierte Initialisierung nicht zulässig.
Stattdessen müssen Sie die traditionelle Listeninitialisierung verwenden, um die geerbten Mitglieder zu initialisieren:
<code class="cpp">Employee e1{ "John", "Wick", 40, 50000 };</code>
Oder, wie in einem Kommentar hervorgehoben, können Sie eine verschachtelte, designierte Initialisierungsliste verwenden, um die Basisklasse zu initialisieren:
<code class="cpp">Employee e1{ { .name{"John"}, .surname{"Wick"}, .age{40} }, 50000 };</code>
In diesem Fall wird die direkte Basisklasse initialisiert unter Verwendung einer bestimmten Initialisierungsliste, während die Employee-Klasse als Ganzes unter Verwendung einer regulären Initialisierungsliste initialisiert wird.
Das obige ist der detaillierte Inhalt vonKönnen designierte Initialisierer verwendet werden, um geerbte Mitglieder in C 20-Aggregaten zu initialisieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!