C では、 std::initializer_list
以下のコード スニペットでは、関数 foo が引数として初期化子リストを受け入れます。
#include <initializer_list> #include <utility> template<typename T> void foo(std::initializer_list<T> list) { for (auto it = list.begin(); it != list.end(); ++it) { bar(std::move(*it)); // Intended to move the element } }
この懸念が生じるのは、std::initializer_list
残念ながら、要素のシームレスな移動に対する期待には根拠がありません。初期化子リストから要素を移動しようとすると、予期しない結果が生じます。要素を再配置する代わりに、コピーが作成されます。この動作は、std::initializer_list
その結果、bar(std::move(*it)) で使用される move 式は、型 T の関数パラメーターにバインドされます。 const & はコピーを効果的に保存します。
この制限の理由は、インスタンスを作成するコンパイラーの特権に起因すると考えられます。静的に初期化される定数としての std::initializer_list。最初と最後で変更可能な結果を許可すると、この最適化が妨げられ、コンパイラーの設計が複雑になります。
予期しない動作にもかかわらず、解決策は目前にある可能性があります。 [ISO 提案](https://github.com/CaseyCarter/iso-changes/blob/master/icpp/p1716r4.md) は、移動専用型の初期化子リストのサポートを導入することを目指しています。この取り組みは、言語の機能を強化し、初期化子リストと移動セマンティクスを操作するためのより一貫したアプローチを提供することを目的としています。
以上がC の `std::initializer_list` から要素を安全に移動できますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。