特定数据类型的模板类

template class for specific data type

本文关键字:数据类型      更新时间:2023-10-16

(为了简单起见,对代码进行了简化(我想创建一个带有模板EA的测试类,同时也创建一个只有E模板的测试类。当我完成这项工作并试图编译我的代码时,我得到了以下错误:

错误C2976:"测试":模板参数太少

注:见"测试"声明

错误C2244:"测试::输出":无法将函数定义与现有申报

错误C2662:"void Test::Output(void(":无法转换"this"从"测试"到"测试&"的指针

错误C2514:"Test":类没有构造函数

#include <iostream>
#include <string>
template <typename E, typename A>
class Test
{
public:
Test(E *e = nullptr, A *a = nullptr) : a(e), b(a) {}
void Output();
private:
E * a;
A *b;
};
template <typename E, typename A>
void Test<E, A>::Output()
{
std::cout << " " << *a << " " << *b;
}
template <typename E>
class Test
{
public:
Test(E *e = nullptr, std::string *a = nullptr) : a(e), b(a) {}
void Output();
private:
E * a;
std::string *b;
};
template<typename E>
void Test<E>::Output()
{
std::cout << *a << *b;
}
int main()
{
int a = 10;
std::string str = "hi";
Test<int> t(&a, &str);
t.Output();
return 0;
}

类模板不能重载(函数模板可以(,而只能是专用的。如果你想要部分专业化,它应该是

template <typename E>
class Test<E, E>
{
...
};

template<typename E>
void Test<E, E>::Output()
{
...
}

使用它时,应该始终指定两个模板参数作为要声明的主模板。即

Test<int, int> t(&a, &str); // the partial specialization will be used

编辑

我可以将第二个模板设置为特定的数据类型(如std::string(吗?并使用类似Test<int, std::string>Test

是。例如

template <typename E>
class Test<E, std::string>
{
...
};

template<typename E>
void Test<E, std::string>::Output()
{
...
}

实时

不幸的是,您不能通过声明template typename E> class Test来"重载"类模板。类Test必须具有两个模板参数。

这里的解决方案是声明一个完全不同的模板类,或者使第二个模板参数可选,并编写一个模板专用化:

class Dummy;
template <typename E, typename A = Dummy>
class Test
…
template <typename E>
class Test<E, Dummy>

所以语法Test<int> t(&a, &str);仍然有效。