为什么这堂课抽象?

时间:2012-07-15 22:33:16

标签: c++ class abstract-class abstract virtual-method

我正在尝试创建表示多项式的LinkedList的实现。链接列表将是“术语”列表。术语是Data的实现(它是一个带有方法的抽象类:compareTo()和toString())。 Polynomial类有一个名为head的变量,我试图将其初始化为Term。我的编译器说我“不能声明抽象类型的成员:Term”,但我不认为Term是抽象的,因为它是Data的一个实现(抽象类)。如果你们可以看看这个,让我知道我失踪的任何巨大的红旗,我将不胜感激。 Collection.h:

  class Data {
  public:
  virtual ~Data() {}

virtual int compareTo(Data * other) const = 0;

virtual string toString() const = 0;
};

class Term : public Data { 
public:
int coefficient;
string variable1;
int exponentX;
string variable2;
int exponentY;
Term * next;

Term(int coeff, string var1, int exp1, string var2, int exp2, Term * next) : 
    coefficient(coeff), 
    variable1(var1),
    exponentX(exp1),
    variable2(var2),
    exponentY(exp2),
    next(next) {};

string convertInt(int number) {
    stringstream ss;//create a stringstream
    ss << number;//add number to the stream
    return ss.str();//return a string with the contents of the stream
}

int compareTo(Term * term) {
    if(this->exponentX > term->exponentX) {
    return 1;
    }
    else if(this->exponentX < term->exponentX) {
    return -1;
    }
    else {
        if(this->exponentY > term->exponentY) {
        return 1;
        }
        else if(this->exponentY < term->exponentY) {
        return - 1;
        }
        else {
        return 0;
        }
    }
}
string toString() {
    stringstream s;
    int * current = &this->coefficient;
    if(*current == 1 || *current == -1) {
    }
    else if(coefficient != 0) {
    s << convertInt(coefficient);
    }
    else { return s.str(); }
    if(variable1 != "" && this->exponentX != 0) {
    s << variable1;
    s << convertInt(exponentX);
    }
    if(variable2 != "" && this->exponentY != 0) {
    s << variable2;
    s << convertInt(exponentY);
    }
return s.str();
}   
};

此外,这里是LinkedList的实现。还有其他一些方法,但它们似乎没有任何问题。

LinkedList.cpp:

 class Polynomial : public LinkedList { 
public:
Term head;

Polynomial() {
this->head = NULL;
}

~Polynomial() {
Term * current = head;
    while (current != NULL) {
        Term * next = current->next;
        delete current;
        current = next;
    }
}

谢谢!

1 个答案:

答案 0 :(得分:6)

当您覆盖虚拟方法时,必须精确匹配功能签名。返回类型可能根据协方差规则而有所不同,但参数类型必须完全相同。

在基类Data中,函数compareTo被声明为

virtual int compareTo(Data * other) const

在派生类Term中,它被声明为

int compareTo(Term * term)

首先,参数类型不同。其次,const缺失。

这意味着您在派生类中编写了一个完全不相关的函数。它不会覆盖基类的纯虚函数。由于基本纯虚函数保持不重写,因此类Term仍然是抽象的。

Term中,您必须将您的功能正确地声明为

int compareTo(Data * other) const

我认为您希望compareToTerm使用Term进行Term - 到 - Data比较。但在此设计中,您必须接收Term作为参数,然后将其转换为Term,或使用双重调度技术。

P.S。最重要的是,您将head对象声明为Polynomial类的成员Term * current = head; ,然后再使用它,就好像它是指针

head

这完全没有意义。如果您希望{{1}}成为指针,请将其声明为指针。如果您希望它是一个对象,则停止将其用作指针。无论是这个还是那个。