Die decltype(auto)-Sprache in C 14 ermöglicht den Abzug des Typs einer Variablen aus einem bestimmten Ausdruck. Während seine primäre Verwendung darin besteht, automatische Deklarationen zu ermöglichen, um DeclType-Regeln einzuhalten, gibt es mehrere andere wertvolle Anwendungen für diese Funktion.
In generischem Code ist es entscheidend, Rückgabetypen perfekt weiterzuleiten, ohne vorher zu wissen, ob der Rückgabewert eine Referenz oder ein Wert ist. decltype(auto) bietet diese Funktionalität:
template<class Fun, class... Args> decltype(auto) Example(Fun fun, Args&&... args) { return fun(std::forward<Args>(args)...); }
Beim Definieren rekursiver Vorlagen kann es zu einer unendlichen Rekursion während der Instanziierung kommen wenn der Rückgabetyp als decltype(...) anstelle von decltype(auto) deklariert ist. Letzteres ermöglicht die Verzögerung der Rückgabetypableitung bis nach der Instanziierung der Vorlage:
template<int i> struct Int {}; constexpr auto iter(Int<0>) -> Int<0>; template<int i> constexpr auto iter(Int<i>) -> decltype(auto) { return iter(Int<i-1>{}); } int main() { decltype(iter(Int<10>{})) a; }
decltype(auto) kann auch in verschiedenen anderen Kontexten verwendet werden , einschließlich Variableninitialisierung:
int i; int&& f(); auto x3a = i; // decltype(x3a) is int decltype(auto) x3d = i; // decltype(x3d) is int auto x4a = (i); // decltype(x4a) is int decltype(auto) x4d = (i); // decltype(x4d) is int& auto x5a = f(); // decltype(x5a) is int decltype(auto) x5d = f(); // decltype(x5d) is int&& auto x6a = { 1, 2 }; // decltype(x6a) is std::initializer_list<int> decltype(auto) x6d = { 1, 2 }; // error, { 1, 2 } is not an expression auto *x7a = &i; // decltype(x7a) is int* decltype(auto)*x7d = &i; // error, declared type is not plain decltype(auto)
Das obige ist der detaillierte Inhalt vonWas sind die praktischen Anwendungen von „decltype(auto)' in C?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!