[英]C++ Polymorphism error: no matching function for call to
我正在尝试将子对象传递给一个函数,该函数接受其父对象的代码:
Rook bRookL();
board[0][0].setPieceObj(bRookL);
我收到以下错误:
ChessBoard.cpp:16:35: error: no matching function for call to 'Space::setPieceObj(Rook (&)())'
board[0][0].setPieceObj(bRookL);
^
In file included from ChessBoard.h:13:0,
from ChessBoard.cpp:5:
Space.h:62:10: note: candidate: void Space::setPieceObj(Piece&)
void setPieceObj(Piece &);
^
Space.h:62:10: note: no known conversion for argument 1 from 'Rook()' to 'Piece&'
这是我的代码:
ChessBoard.h:
#ifndef CHESSBOARD_H
#define CHESSBOARD_H
#include "Space.h"
using namespace std;
class ChessBoard {
private:
Space board[8][8]; // board[0][0] is the upper-left corner of the board and
// board[7][7] is the lower-right corner of the board
public:
ChessBoard();
};
#endif /* CHESSBOARD_H */
ChessBoard.cpp:
#include "ChessBoard.h"
#include "Space.h"
#include "Rook.h"
using namespace std;
ChessBoard::ChessBoard() {
Rook bRookL();
board[0][0].setPieceObj(&bRookL);
}
Rook.h:
#ifndef ROOK_H
#define ROOK_H
#include "Piece.h"
using namespace std;
class Rook : public Piece {
public:
Rook() : Piece() {
}
};
#endif /* ROOK_H */
Piece.h:
#ifndef PIECE_H
#define PIECE_H
using namespace std;
class Piece {
public:
Piece() {
}
};
#endif /* PIECE_H */
Space.h:
#ifndef SPACE_H
#define SPACE_H
#include "Piece.h"
#include "Rook.h"
using namespace std;
class Space {
private:
Piece *pieceObj;
public:
void setPieceObj(Piece &);
};
#endif /* SPACE_H */
Space.cpp:
#include "Space.h"
using namespace std;
Space::Space() {
}
void Space::setPieceObj(Piece &p) {
pieceObj = p;
}
请帮忙。 谢谢。
基于对代码的检查,似乎setPieceObj()应该采用指针参数:
void Space::setPieceObj(Piece *p) {
pieceObj = p;
}
这是一个问题。 现在,您需要将指针传递给Piece
对象。
Rook bRookL();
board[0][0].setPieceObj(&bRookL);
这是一个最令人烦恼的解析 ,它声明了一个返回Rook
的函数,并将指针传递给setPieceObj()。
没有足够的信息来确定您的明确意图。 也许:
Rook bRook;
board[0][0].setPieceObj(&bRookL);
Rook bRookL();
board[0][0].setPieceObj(&bRookL);
1. Rook bRookL();
没有做你期望的,它是一个函数声明,它不带参数并返回Rook
,即Rook (*)()
(就像编译器告诉你的那样)。
2. &bRookL
将返回的地址bRookL
,所以这将是一个指针。 但是Space::setPieceObj(Piece &p)
期望它的参数是Piece&
。 您似乎应该将参数类型更改为Piece*
以使它们保持一致。
然后
Rook bRookL;
board[0][0].setPieceObj(&bRookL);
指针( &bRookL
)无法转换为引用( Piece&
)。
最有可能的解决方案是声明setPiece
应该采用指针:
void setPieceObj(Piece*);
哪个应该实际上使定义也可以编译:
void Space::setPieceObj(Piece* p) {
pieceObj = p;
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.