关于模板专业化和结果代码复制的问题

时间:2009-01-31 17:54:12

标签: c++ templates

要专门化类模板,必须重新定义底层基本模板中的所有成员函数(即非专用类模板),即使它们预计基本保持不变。有哪些可接受的方法和“最佳实践”可以避免此代码重复?

感谢。

2 个答案:

答案 0 :(得分:10)

您可以有选择地完全专门化成员:

template<int N>
struct Vector {
    int calculate() { return N; }
};

// put into the .cpp file, or make inline!
template<>
int Vector<3>::calculate() { return -1; }

你完全专业化。意思是你不能局部专门化它:

template<int N, int P>
struct Vector {
    int calculate() { return N; }
};

// WROOONG!
template<int N>
int Vector<N, 3>::calculate() { return -1; }

如果需要,可以使用enable_if:

template<int N, int P>
struct Vector { 
    int calculate() { return calculate<P>(); }
private:
    // enable for P1 == 3
    template<int P1>
    typename enable_if_c<P1 == P && P1 == 3, int>::type
    calculate() { return -1; }

    // disable for P1 == 3
    template<int P1>
    typename enable_if_c<!(P1 == P && P1 == 3), int>::type
    calculate() { return N; }
};

另一种方法是将你的东西(普通的东西分成基类,特殊的东西分成派生类)分开,就像尼克推荐的那样。

我通常采取第二种方法。但如果我不需要部分专门化功能,我更喜欢第一个。

答案 1 :(得分:4)

我经常在出现这种情况时使用基类。即:将通用功能放在基类中,并从中派生模板类,然后使用不同的函数专门化派生类。