模板的赋值运算符(成员函数)实现的正确语法
Correct syntax of assignment operator (member function) implementation for a template
这是.hpp文件:
template<typename T>
LinkedQueue<T> operator=(const LinkedQueue<T> & lhs, const LinkedQueue<T> & rhs)
{
m_data = rhs.m_data;
m_next = rhs.m_next;
}
该错误指出第一行必须是非静态成员函数。 这是它所在的类:
template<typename T>
class LinkedQueue:public AbstractQueue<T>
{
public:
T m_data;
LinkedQueue *m_next;
LinkedQueue<T> operator=(const LinkedQueue<T> & rhs);
LinkedQueue();
void clear();
void enqueue(T x);
void dequeue();
const T& front() const;
bool isEmpty() const;
};
知道我做错了什么愚蠢的事情吗?
您应该向函数定义添加一个类限定符,并删除未使用的 lhs
参数:
template<typename T>
LinkedQueue<T>& LinkedQueue::operator=(const LinkedQueue<T> & rhs)
// ^--- & should be added to the declaration, too
{
m_data = rhs.m_data;
m_next = rhs.m_next;
return *this;
}
你应该写成这样;
template<typename T>
class LinkedQueue:public AbstractQueue<T>
{
public:
T m_data;
LinkedQueue *m_next;
LinkedQueue<T> & operator=(const LinkedQueue<T> & rhs)
{
if (this != &rhs)
{
m_data = rhs.m_data;
m_next = rhs.m_next;
}
return *this;
}
LinkedQueue();
void clear();
void enqueue(T x);
void dequeue();
const T& front() const;
bool isEmpty() const;
};
相关文章:
- 解释通过 lex/flex 实现 C/C++嵌套的"#include "Header""语法?
- priority_queue使用降序向量实现最小堆的语法差异
- 如何在编译器C++不智能的情况下实现 GLSL vec* 构造语法?
- 如何使用 Boost.Asio 正确实现异步/等待语法
- 像这样的PIMPL实现是否有任何简单的语法
- 在任何编译语言中实现以下语法(用于工厂设计模式)? 最好是 Kotlin,C++
- 如何使用自然外观的语法实现线程安全容器
- 在C 中,可以用语法[i,j,..]实现访问数组元素的功能,而语法就像numpy中的ndarray样式一样
- 我不理解这个dfs实现的语法
- 如何使用两个单独的语法实现计算机翻译器
- 强类型枚举的语法实现错误
- GCC 4.4 不实现 C++11 范围循环.它还支持哪些其他范围循环语法
- 模板的赋值运算符(成员函数)实现的正确语法
- 实现功能齐全的移位流语法
- 用C++实现Matlab语法
- 在不使用专用语法的情况下,为不同类型的不同方式实现模板类的方法是否有效C++?
- Boost是如何实现这样的语法的
- 在我的解释器上为脚本代码实现语法检查器的最佳方式是什么
- 实现[B,C]=f(A)语法(函数f作用于具有两个或多个输出数组的数组)
- 通过move赋值实现B=f(A)语法