Why full specialization of template function is not picked up from the .cpp file without declaration?

后端 未结 3 1136
盖世英雄少女心
盖世英雄少女心 2021-01-23 04:42

Following code generate no compilation/linker error/warning:

// A.h
#include
struct A
{
  template
  static void foo (T t)
  {
         


        
相关标签:
3条回答
  • 2021-01-23 05:16

    All explicit specialization declarations must be visible at the time of the template instantiation. Since your explicit specialization declaration for A::foo<double> is visible in one translation unit but not the other, the program is ill-formed.

    (In practice, the compiler will instantiate the primary template in main.cpp and the explicitly-specialized one in other.cpp. That would still an ODR violation anyway.)

    0 讨论(0)
  • 2021-01-23 05:34

    main.cpp cannot see the code inside other.cpp. Template specializations are of file scope.

    0 讨论(0)
  • 2021-01-23 05:41

    Why compiler is not able to pick up the correct A::foo(double) in case of main.cpp ?

    The problem is that in a separate compilation model without a declaration available in the header the compiler wouldn't possibly know whether an specialization exists in any translation unit that will later be linked or whether it needs to instantiate the template. The decision in the language is that the absence of a declaration means that there is no manual specialization of the template, and thus the compiler needs to generate one now.

    is having 2 different version of the same function an Undefined Behavior ?

    Yes it is. Whether one of the specializations was automatically generated or not, the fact is that it is undefined behavior as it is a violation of the One Definition Rule (there are multiple definitions of the same symbol).

    0 讨论(0)
提交回复
热议问题