首页 > 解决方案 > 构造函数的部分模板特化

问题描述

我需要一个看起来像这样的类:

template<typename T, class S, size_t C>
class myClass
{
public:
    myClass(); // Ctor

    /*


    */
private:
S myData;
}

其中 T 是存储数据的类型,S 是容器类型,C 是它的大小。方法将不依赖于容器类型,但我仍然需要正确初始化 S。例如,让 S be std::vector,我尝试过:

template<typename T, size_t C>
myClass<T, std::vector<T>, C>::myClass()
{

}

但我得到E0040 expected identifier错误。

标签: c++templates

解决方案


您不能部分专门化一个方法,您可以部分专门化整个类,但需要一些重复。

由于您可以使用 C++17,因此您可以调整实现:

template<typename T, class S, size_t C>
myClass<T, S, C>::myClass()
{
    if constexpr (std::is_same_v<S, std::vector<T>>) {
        // special case
    } else {
        // regular case
    }
}

在另一个选项(C++ 17 之前)中标记 dipatching,其优点是允许成员初始化器列表:

template <typename T> struct tag{}; 

template <typename T, class S, size_t C>
class myClass
{
private:
    myClass(tag<std::vector<T>>) : myData(/*special case */) {/* special case */}

    template <typename U>
    myClass(tag<U>) : myData(/*regular case */) {/* regular case */}

public:
    myClass() : myClass(tag<S>{}) {}

private:
    S myData;
};

推荐阅读