我正在尝试实现模板化类MyQueue(逻辑结构是环形缓冲区):
// MyQueue.h
#pragma once
template<typename T>
class MyQueue
{
public:
/* interface */
MyQueue(int sizeOfBuffer);
void push(const T& elem);
T pop(void);
private:
T* m_array;
};
template<typename T>
MyQueue<T>::MyQueue(int sizeOfBuffer)
{
m_array = new T[sizeOfBuffer];
}
通常当我面对模板类中构造函数的实现时,我在声明中实现它:
#pragma once
template<typename T>
class MyQueue
{
public:
/* interface */
MyQueue(int sizeOfBuffer){// do some actions with argument sizeOfBuffer};
void push(const T& elem);
T pop(void);
private:
T* m_array;
};
由于构造函数的主体可以占用大量空间,我决定将其与声明(但在相同的标题中)一起实现,以使代码更具可读性。
问题:我做错了什么以及如何解决我的问题?
答案 0 :(得分:3)
这与你如何编写构造函数的主体无关。
这与你显然试图创建这个类的默认构造对象的事实有关,但是你还没有提供默认的构造函数。通常情况下,编译器会合成一个默认构造函数,但由于您编写了一个带参数的构造函数,编译器也不会(自动)执行此操作。
使用最近的编译器,您应该能够使用C ++ 11中引入的= default;
语法来获取默认构造函数。否则,您需要显式编写一个,或者向现有构造函数添加默认参数(例如MyQueue(int sizeOfBuffer = 20);
)。