我对派生类中重新定义和重写函数之间的区别感到困惑。在C++中重新定义与重写
我知道 - 在C++中,重新定义的函数是静态绑定的,重写的函数是动态绑定的,并且重写了虚拟函数,并重新定义了非虚函数。
当一个派生类“重新定义”了一个基类中的方法时,其被重新定义。但是当派生类是虚拟的时,它不再重新定义,而是重写。所以我理解规则的后勤,但我不明白底线。
在下面的示例中,函数SetScore被重新定义。但是,如果我使基类虚拟的setScore函数(通过向其添加虚拟字),派生类中的setScore将被覆盖。我不明白底线 - 有什么区别。在setScore?
基类:
class GradedActivity
{
protected:
char letter; // To hold the letter grade
double score; // To hold the numeric score
void determineGrade(); // Determines the letter grade
public:
// Default constructor
GradedActivity()
{ letter = ' '; score = 0.0; }
// Mutator function
void setScore(double s)
{ score = s;
determineGrade();}
// Accessor functions
double getScore() const
{ return score; }
char getLetterGrade() const
{ return letter; }
};
派生类:
class CurvedActivity : public GradedActivity
{
protected:
double rawScore; // Unadjusted score
double percentage; // Curve percentage
public:
// Default constructor
CurvedActivity() : GradedActivity()
{ rawScore = 0.0; percentage = 0.0; }
// Mutator functions
void setScore(double s)
{ rawScore = s;
GradedActivity::setScore(rawScore * percentage); }
void setPercentage(double c)
{ percentage = c; }
// Accessor funtions
double getPercentage() const
{ return percentage; }
double getRawScore() const
{ return rawScore; }
};
这是主要:
// Define a CurvedActivity object.
CurvedActivity exam;
...
// Send the values to the exam object.
exam.setPercentage(percentage);
exam.setScore(numericScore);
覆盖有助于类多态性。重载有利于函数多态性。重新定义既不会也是错误。 – orfdorf 2014-11-04 20:10:47