c++ - 指针似乎在递归算法中迷路了
问题描述
我正在尝试执行递归洪水填充算法,并且正在将指针传递给参数中的某些数据结构。在算法运行的某个时刻,指针似乎丢失了。我不知道为什么。
代码解释:首先算法检查块溢出,这意味着需要保存旧块并加载新块,基于 X 和 Y。接下来是替换块结构中的一些数据,然后是递归函数调用。
bool WorldGenerator::floodFillStep(int _x, int _y, int _target, int _replacement, Chunk* _chunk)
{
Chunk* chunk = _chunk;
if (_x < (xSize * CHUNK_WIDTH) && _y < (ySize * CHUNK_HEIGHT))
{
int x = _x % CHUNK_WIDTH,
y = _y % CHUNK_HEIGHT,
X = _x / CHUNK_WIDTH,
Y = _y / CHUNK_HEIGHT;
//check for chunk spill
if ((floodLastX / CHUNK_WIDTH) < X)
{
chunk->save();
std::string path = "maps/" + std::to_string(X) + std::to_string(Y) + ".map";
chunk->load(path, X, Y);
}
else if ((floodLastY / CHUNK_HEIGHT) < Y)
{
chunk->save();
std::string path = "maps/" + std::to_string(X) + std::to_string(Y) + ".map";
chunk->load(path, X, Y);
}
else if ((floodLastX / CHUNK_WIDTH) > X)
{
chunk->save();
std::string path = "maps/" + std::to_string(X) + std::to_string(Y) + ".map";
chunk->load(path, X, Y);
}
else if ((floodLastY / CHUNK_HEIGHT) > Y)
{
chunk->save();
std::string path = "maps/" + std::to_string(X) + std::to_string(Y) + ".map";
chunk->load(path, X, Y);
}
floodLastX = _x;
floodLastY = _y;
//replacement
if (chunk->getTile(x, y)->getType() == _target)
{
if (x < 40 && y < 40 && x >= 0 && y >= 0)
{
chunk->getTile(x, y)->setType(_replacement);
chunk->getTile(x, y)->setMod(255);
//_chunk->save();
floodFillStep(_x + 1, _y, _target, _replacement, chunk);
floodFillStep(_x, _y + 1, _target, _replacement, chunk);
floodFillStep(_x - 1, _y, _target, _replacement, chunk);
floodFillStep(_x, _y - 1, _target, _replacement, chunk);
}
}
}
return true;
}
在某些时候,抛出与 Chunk 实例内的 std::vector 相关的异常,当我检查局部变量时,指向 Chunk 的指针无效。当指向块的指针可能会丢失时有什么想法吗?
谢谢
解决方案
我已经弄清楚了,这是与堆栈相关的,几乎无法重现的问题,因此无需更深入的解释。那个 Chunk* chunk = _chunk 我只是在尝试一些东西,并没有删除所有过时的代码。
推荐阅读
- sql - 创建表时行的顺序发生变化
- html - HTML 电子邮件签名 Outlook 2016 中的视网膜图像
- ruby-on-rails - Rspec:Capybara 服务器映射一个目录
- ios - Kontakt.io iOS - 按名称识别信标
- mysql - Node Js (Sequelize) - 未处理的拒绝 SequelizeDatabaseError:“字段列表”中的未知列“id”
- javascript - 在 Internet Explorer 上悬停表格标题时不显示工具提示
- c# - 有没有办法可以从一些文本和参数列表中创建一个字符串?
- c# - 从另一个程序打开 Solidworks PDM 目录
- powershell - 如何过滤 Get-ADComputer 输出
- docker - 在 Mesos / Marathon 中设置默认的 docker run 参数