ホームページ >バックエンド開発 >C++ >C 11 の「extern template」は冗長なテンプレートのインスタンス化をどのように回避できますか?

C 11 の「extern template」は冗長なテンプレートのインスタンス化をどのように回避できますか?

DDD
DDDオリジナル
2024-12-20 14:59:13329ブラウズ

How Can `extern template` in C  11 Avoid Redundant Template Instantiations?

extern テンプレートによるテンプレートのインスタンス化の回避 (C 11)

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 をインスタンス化しないように指示されます。 source1.cpp では、プロジェクト内で 1 回だけインスタンス化されるようにします。

重要な考慮事項

extern テンプレートの使用は、次のような状況に限定する必要があります。テンプレートが別の場所でインスタンス化されることがわかっています。インスタンス化されていない場合、プログラムは未解決の参照を生成します。ベスト プラクティスとして、すべてのテンプレートのインスタンス化を 1 つのヘッダー ファイルで宣言し、異なるファイルでの複数のインスタンス化によって引き起こされる潜在的な問題を回避することをお勧めします。

以上がC 11 の「extern template」は冗長なテンプレートのインスタンス化をどのように回避できますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。