因此,我有一个Piece类,应该代表板上的棋子,我计划从中继承其他两个类。但是,这样做有很多问题。这是到目前为止的相关代码。
///
/// PIECE CLASS HERE
/// this is an abstract class from which Barrier and Pawn inherit.
class Piece
{
public:
Piece(Space* start);
sf::Shape m_Circle;
protected:
int m_X;
int m_Y;
int m_radius;
Space* CurrentSpace;
};
Piece::Piece(Space* start):
m_X(start->GetX()),
m_Y(start->GetY()),
m_radius(14),
CurrentSpace(start)
{}
///
/// BARRIER CLASS HERE
/// these are the white stones that block a player's path
class Barrier : public Piece
{
public:
Barrier(Space* initial);
void Move(Space* target, bool isCapturing);
};
Barrier::Barrier(Space* initial)
{
Piece(initial);
m_Circle = sf::Shape::Circle((float)m_X, (float)m_Y, (float)m_radius, sf::Color(255, 255, 255));
Move(initial);
}
void Barrier::Move(Space* target, bool isCapturing)
{
int xChange = abs(target->GetX() - m_X);
int yChange = abs(target->GetY() - m_Y);
m_Circle.Move((float)xChange, (float)yChange);
CurrentSpace.ToggleOccupied();
if(!isCapturing)
{
(*target).ToggleOccupied();
}
CurrentSpace = target;
}
我遇到了很多我不了解的错误,尤其是:
no matching function for call to Piece::Piece()
declaration of 'Piece initial' shadows a parameter
no matching function for call to 'Barrier::Move(Piece&)'
request for member 'ToggleOccupied' in '((Barrier*)this)->Barrier::<anonymous>.Piece::CurrentSpace', which is of non-class type 'Space*'|
作为C++的新手,我不明白这是怎么回事。我尝试构建类似于在我以前学习C++的书中找到的代码的代码,但是显然我忽略了一些细微之处。我认为,我尝试调用的所有功能似乎都存在于适当的位置,并且我以与原型(prototype)中相同的值来定义它们。
最佳答案
第一个错误是由以下原因引起的:
Barrier::Barrier(Space* initial)
{
Piece(initial);
m_Circle = sf::Shape::Circle((float)m_X, (float)m_Y, (float)m_radius, sf::Color(255, 255, 255));
Move(initial);
}
需要看起来像:
Barrier::Barrier(Space* initial) : Piece(initial)
{
m_Circle = sf::Shape::Circle((float)m_X, (float)m_Y, (float)m_radius, sf::Color(255, 255, 255));
Move(initial);
}
基类的构造函数在构造函数之前运行(无论如何)-如果在初始化列表中需要参数,则需要向其传递参数。
我不确定其他错误,因为我不知道它们发生在哪一行。
关于c++ - 我搞砸了我的遗产,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/6347637/