复制构造函数中的模板
template in copy constructor
你能告诉我为什么我会得到编译错误吗
template<class T> class 'Node' used without template parameters
带有以下代码
template<class T>
class Node
{
private:
T _value;
vector<Node*> children;
public:
Node(T value);
Node<T>(const Node<T>& node);
void AddChild(Node<T>* node);
T getValue();
vector<Node<T>*> returnChildren();
~Node();
};
template <class T>
Node::Node<T>(T value):_value(value)
{
}
template <class T>
Node<T>::Node(T value):_value(value)
{
}
试试这个。
当您编写时
Node::Node<T>(T value):_value(value)
类上没有模板参数(该行的第一个Node
),但构造函数上有一个模板参数(第二个Node
)。这是不正确的。
在您的例子中,Node
是模板类。使用该类时,必须将其与模板参数一起使用。这不起作用:
template <class T>
Node::Node(T value):_value(value)
{
}
因为类Node
是模板化的,并且您使用它时没有模板参数。
这也不起作用,因为你把模板参数放在函数(这里是构造函数)上,而不是类上。
template <class T>
Node::Node<T>(T value):_value(value)
{
}
这确实有效。
template <class T>
Node<T>::Node(T value):_value(value)
{
}
此语法仅用于类,在编写函数时会有所不同。
用于函数
假设我们有这个级别的
class MyTemplate
{
template<typename T>
void foo(T val);
};
你可以这样定义方法:
template<typename T>
void MyTemplate::foo<T>(T val)
{
};
但它失败了。Clang打印此错误:
不允许函数模板部分专业化
对于您不需要的功能,您必须编写
template<typename T>
void MyTemplate::foo(T val)
{
}
如果你想专门化它,你可以写
template<>
void MyTemplate::foo(int val)
{
}
或
template<>
void MyTemplate::foo<int>(int val)
{
}
声明:
当您声明Node类型的变量时,您还必须使用模板参数。
Node<int> myNode(12);
相关文章:
- C++17复制构造函数,在std::unordereded_map上进行深度复制
- 为什么在C++中使用私有复制构造函数与删除复制构造函数
- 当从函数参数中的临时值调用复制构造函数时
- 如果有一个模板构造函数只有一个泛型参数,为什么我必须有一个复制构造函数
- 使用复制构造函数复制双精度数组
- C 无可行的构造函数复制类型的变量
- 没有可行的构造函数复制类型 'MyString' 的数组元素
- 编译时,复制构造函数/复制分配和正常功能调用优化之间是否存在任何区别
- 如何最小化调用列表构造函数(复制构造函数)的次数?
- C 11矢量构造函数复制与范围
- 我定义了一个非复制构造函数;复制构造函数还会被隐式定义吗
- 可以将构造函数复制为转换运算符
- 将基类指针的构造函数复制到子类
- C++树类:构造函数/复制/内存泄漏
- 如何制作这个在模板构造函数复制中使用类型定义的类型的模板
- 将构造函数复制为模板化的成员函数
- 绕过私有复制构造函数/复制赋值C++
- C++通过构造函数复制对象
- 复制构造函数 - 复制C++中的对象
- 将带unique_ptr的类的构造函数复制到作为成员的抽象类