我相信我的问题很简单,但我无法克服。

我有抽象模板类aghContainer和子模板类aghVector。我正在尝试制作aghVector对象,但出现错误,我无法创建抽象类的对象。我很确定我实现了所有方法,但是也许我错过了一些东西...

aghContainer:

template <typename T>
class aghContainer {
public:
    virtual ~aghContainer() {}
    virtual void append(T const&) = 0;
    virtual void append(aghContainer<T> const& right) = 0;
    virtual bool replace(const int, T const&) = 0;
    virtual T& at(const int) const = 0;
    virtual int size(void) const = 0;
    virtual bool remove(const int) = 0;
    virtual void clear(void) = 0;
    virtual bool isEmpty(void) = 0;
    virtual int indexOf(T const& _value, int _from = 0) const = 0;
    virtual bool contains(T const& _value, int _from = 0) const = 0;
    virtual void print(ostream&) const = 0;
    virtual bool equal(aghContainer<T> const& right) const = 0;
    virtual bool operator==(aghContainer<T> const& right) const;
    virtual bool operator!=(aghContainer<T> const& right) const;
    virtual T& operator[](const int n) const;
    virtual aghContainer<T>& operator+=(T const& element);
    virtual aghContainer<T>& operator+=(aghContainer<T> const& right);
    virtual aghContainer<T>& operator<<(T const& element);
    virtual aghContainer<T>& operator<<(aghContainer<T> const& right);
    friend ostream& operator<<(ostream&, aghContainer<T> const& right);
};

aghVector:
template <typename T>
class aghVector :
    public aghContainer<T> {
public:
    aghVector();
    ~aghVector();
    void append(T const&);
    void append(aghContainer<T> const& right);
    bool insert(const int, T const&);
    bool replace(const int, T const&);
    T& at(const int) const;
    int size(void) const;
    bool remove(const int);
    void clear(void);
    bool isEmpty(void);
    int indexOf(T const& _value, int _from = 0);
    bool contains(T const& _value, int _from = 0) const;
    void print(ostream&) const;
    bool equal(aghContainer<T> const& right) const;

private:
    T* vector;
    unsigned int elements;
    void destroyVector();
};

错误:

最佳答案

我可以快速查看几个问题。

aghContainer

 void append(aghContainer<T> const& right) = 0;

aghVector
  void append(aghVector<T> const& right);

实际上会使用不同的参数类型重载该函数(因为aghVector是与aghContainer不同的类型。继承的append()将被隐藏而不被覆盖。
equal()的类似问题。
indexOf()中的aghContainer声明为const,而aghVector中的声明则不是。因此,再次,aghVecvtor中的版本将隐藏继承的函数,并且不会覆盖它。

10-08 02:19