10

gcc 4.5.1,SuSE Linux i686

假设我们有以下代码:

template<typename realT> class B
{
public:
    B() {std::cout << "B()" << std::endl;}
};

template<typename realT> class A
{
public:
    static B<realT> static_var;
};

template<typename realT> B<realT> A<realT>::static_var;
template<> B<float> A<float>::static_var;
template<> B<double> A<double>::static_var;

int main()
{
    A<float> test;
    return 0;
}

在这种情况下,我们在标准输出中不会有任何输出。编译器不会生成代码来初始化 A 类的浮点和双重特化。

但是..如果我们像这样改变初始化:

template<> B<float> A<float>::static_var = B<float>();
template<> B<double> A<double>::static_var = B<double>();

编译器将生成这样的代码,我们将在输出中包含双“B()”。

有人可以帮助我理解这种行为吗?

4

1 回答 1

8

n3337 14.7.3/13

如果声明包含初始化器,则模板的静态数据成员的显式特化是定义;否则,它是一个声明。[注意:需要默认初始化的模板的静态数据成员的定义必须使用花括号初始化列表:

template<> X Q<int>::x; // declaration
template<> X Q<int>::x (); // error: declares a function
template<> X Q<int>::x { };// definition

——尾注]

braced-init-listC++11功能,所以C++03你只能使用

template<> X Q<int>::x = ...;
于 2012-09-12T09:34:36.293 回答