C 11 の extern template キーワードは、不必要なテンプレートのインスタンス化を防止するメカニズムを提供し、コンパイル時間とオブジェクト ファイルを削減します。サイズ。特定のシナリオでは、テンプレートが別の場所でインスタンス化されることを認識し、このキーワードを使用してコンパイラにインスタンス化を実行しないように指示すると有益です。
質問に示されている例とは異なり、extern template キーワードは関数テンプレートにも使用できます。次の例を考えてみましょう。
// header.h template<typename T> void bigFunc(); // source1.cpp #include "header.h" void something1() { bigFunc<int>(); } // source2.cpp #include "header.h" extern template void bigFunc<int>(); // This prevents its compilation in source2.cpp void something2() { bigFunc<int>(); }
extern テンプレート ステートメントがないと、bigFunc はsource1.cpp とsource2.cpp の両方でコンパイルされ、オブジェクト コードが冗長になります。 extern テンプレートを使用すると、コンパイラは、source2.cpp で bigFunc をインスタンス化しないように指示され、コンパイル時間とオブジェクト ファイル サイズが削減されます。
質問の図 2 に示されているように、extern テンプレートはクラスにも使用できますtemplates:
// header.h template<typename T> class myClass { T getValue(); }; // source1.cpp #include "header.h" extern template class myClass<int>; // Prevent instantiation here void something1() { myClass<int> obj; obj.getValue(); }
このシナリオでは、コンパイラーは myClass
extern テンプレートの使用は、次のような状況に限定する必要があります。テンプレートが別の場所でインスタンス化されることがわかっています。インスタンス化されていない場合、プログラムは未解決の参照を生成します。ベスト プラクティスとして、すべてのテンプレートのインスタンス化を 1 つのヘッダー ファイルで宣言し、異なるファイルでの複数のインスタンス化によって引き起こされる潜在的な問題を回避することをお勧めします。
以上がC 11 の「extern template」は冗長なテンプレートのインスタンス化をどのように回避できますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。