gpt4 book ai didi

c++ - 析构函数和指向类属性的指针

转载 作者:太空宇宙 更新时间:2023-11-04 15:50:54 26 4
gpt4 key购买 nike

我有这个类 ChessBoard,这是它的标题:

class ChessBoard
{
Field** board;
Color currentColor;

public:
ChessBoard();
ChessBoard(const ChessBoard&);
Field* findField(std::string);
ChessBoard& operator = (const ChessBoard&);

bool checkIfFieldHasFigure(std::string);


void writeOneState(SahApi*);
void playAllMoves(std::istream*, SahApi*);
void playMove(std::string);
~ChessBoard();

};

我有它的构造函数,它创建了棋盘的开始阶段:(非常可怕,我知道 :) )

ChessBoard::ChessBoard()
{
int i, j;
Error err;
board = new Field*[8];
if(!board)
{
err.writeToOutput(1);
exit(1);
}
for(i = 0; i < 8; i++)
{
board[i] = new Field[8];
if(!board[i])
{
err.writeToOutput(1);
exit(1);
}
}
currentColor = WHITE;
char c;
std::string s;
Figure f;
for(i = 0; i < 8; i++)
for(j = 0; j < 8; j++)
{
s.clear();
c = i + 'A';
s.push_back(c);
c = j + '1';
s.push_back(c);
board[i][j].position.assign(s);

if((j > 1) && (j < 6))
board[i][j].hasFigure = 0;
else board[i][j].hasFigure = 1;

if((i+j+2) % 2)
board[i][j].color = WHITE;
else board[i][j].color = BLACK;

if( ((j==0)||(j==7)) && ((i==0)||(i==7)) )
{
Rook* r = new Rook(((j==0)?WHITE:BLACK), s);
if(!r)
{
err.writeToOutput(1);
exit(1);
}
board[i][j].putFigure(r);
}
else if( ((i==1)||(i==6)) && ((j==0)||(j==7)) )
{
Knight* n = new Knight(((j==0)?WHITE:BLACK), s);
if(!n)
{
err.writeToOutput(1);
exit(1);
}
board[i][j].putFigure(n);
}
else if( ((i==2)||(i==5)) && ((j==0)||(j==7)) )
{
Bishop* b = new Bishop(((j==0)?WHITE:BLACK), s);
if(!b)
{
err.writeToOutput(1);
exit(1);
}
board[i][j].putFigure(b);
}
else if( (i==3) && ((j==0)||(j==7)))
{
Queen* q = new Queen(((j==0)?WHITE:BLACK), s);
if(!q)
{
err.writeToOutput(1);
exit(1);
}
board[i][j].putFigure(q);
}
else if( (i==4) && ((j==0)||(j==7)) )
{
King* k = new King(((j==0)?WHITE:BLACK), s);
if(!k)
{
err.writeToOutput(1);
exit(1);
}
board[i][j].putFigure(k);
}
else if( (j==1) || (j==6) )
{
Pawn* p = new Pawn(((j==1)?WHITE:BLACK), s);
if(!p)
{
err.writeToOutput(1);
exit(1);
}
board[i][j].putFigure(p);
}
}
}

我还需要一个 ChessBoard 的析构函数,它是这样的:

ChessBoard::~ChessBoard()
{
//for(int i = 0; i < 8; i++)
// delete board[i];
delete [] board;
}

部分被注释掉的原因是我的第一个问题:

<强>1。为什么我不能用上面写的方法删除我所有的字段? 当我尝试这样做时,程序进入“ block 类型有效”错误,我知道这是由于试图删除不存在的内存引起的。当我将其注释掉时,该程序运行良好。 ChessBoard 是一个 8x8 矩阵,所以我应该可以像我在这里尝试的那样删除它。

我的第二个问题是:

<强>2。如何删除我的棋盘构造函数中存在的指向数字(国王、王后、车等)的指针?这很令人困惑,因为这些指针用作我的棋盘的一部分,而我使用它们直到节目结束。当程序结束时,我需要释放内存,但我不知道如何访问这些指针。数字本身会被自动删除,因为它们都是非指针。 我什至需要删除那些指针,因为我使用它们直到最后,然后所有内容都被释放了吗?

最佳答案

  1. 新建/删除的一般规则是调用必须相互匹配。你用

    创建你的板
    board = new Field*[8];
    for(i = 0; i < 8; i++)
    {
    board[i] = new Field[8];
    }

    您将需要以相同的方式删除您的看板,但要倒退:

    for(i = 0; i < 8; i++)
    {
    delete [] board[i];
    }
    delete[] board;

    由于这不起作用,我猜您的问题是双重删除。其他东西正在释放阵列。您是否有指向同一个 Field** 的 ChessBoard 拷贝?

  2. 您将不得不以类似的方式删除您的图形。

    for (int x = 0; x < 8; x ++)
    for (int y = 0; y < 8 ;y ++)
    if (board[y][x] != NULL)
    delete board[y][x];

    只要您从板上删除图形的代码删除了该图形并将该图形的位置设置为 NULL,此代码就可以工作。

    2b。你的 2 问题的第二部分是你是否必须完全删除任何内容,因为程序正在结束。你是对的,因为如果你要立即退出,你不需要删除任何东西,操作系统无论如何都会为你释放所有内存。

不过,您通常应该这样做,通常您最终会通过允许它们运行多次来修改大多数程序,然后您发生内存泄漏,因为每次运行都会使用更多的内存。


这就是如何解决你的问题。但是,我强烈建议您更改大部分代码的样式并删除所有动态分配。

首先,使用常规静态大小的数组 (Field[8][8]) 来存储字段。我的意思是,棋盘何时会改变大小?

其次,按值存储片段。如果片段在某个位置,您的字段类已经存储。还让 Field 类存储一个代表类型的枚举。没有理由为您的作品使用动态分配。

第三,不需要检查new的返回是否为NULL。如果有错误,它将抛出异常,您的程序将停止(因为它应该,当您内存不足时您无能为力)。

关于c++ - 析构函数和指向类属性的指针,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8548905/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com