C 14 の decltype(auto) イディオムでは次のような演繹が可能です。指定された式から変数の型を取得します。この機能の主な用途は、自動宣言が decltype ルールに準拠できるようにすることですが、この機能には他にもいくつかの有益な用途があります。
template<class Fun, class... Args> decltype(auto) Example(Fun fun, Args&&... args) { return fun(std::forward<Args>(args)...); }ジェネリック コード内では、戻り値が参照であるか値であるかを事前に知らなくても、戻り値の型を完全に転送することが重要です。 decltype(auto) は次の機能を提供します:
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) ではなく decltype(...) として宣言されている場合。後者では、テンプレートのインスタンス化後まで戻り値の型の推定を遅らせることができます:
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)decltype(auto) は、他のさまざまなコンテキストでも利用できます。 、変数の初期化を含む:
以上がC における `decltype(auto)` の実際の応用例は何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。