函数调用调用者没有明显的原因

时间:2013-07-22 16:50:04

标签: c++ g++ mingw

我使用过剩来做一个简单的游戏。过剩显示回调如下所示:

std::chrono::duration<float> timeDelta = std::chrono::high_resolution_clock::now() - lastFrame;
lastFrame = std::chrono::high_resolution_clock::now();
std::cout << (1 / timeDelta.count()) << "fps" << std::endl; // print fps

game->draw();

std::cout << "finished frame"  << std::endl << std::endl;

glutSwapBuffers();

由于某种原因,该功能永远不会完成,控制台输出如下所示:

166.639fps
draw game
166.667fps
draw game

无限重复。

draw函数如下所示:

std::cout << "draw game" << std::endl;
glBindFramebuffer(GL_FRAMEBUFFER, framebuffer);
glClearColor(RENDER_BRIGHTNESS, RENDER_BRIGHTNESS, RENDER_BRIGHTNESS, 1);
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);

camera.draw();
world.draw();

//Bind 0, which means render to back buffer
glBindFramebuffer(GL_FRAMEBUFFER, 0);

glViewport(0, 0, width, height);

glClearColor(1, 1, 1, 1);
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);

glMatrixMode(GL_PROJECTION);
glLoadIdentity();
glOrtho(0, width, 0, height, -1, 1);

glMatrixMode(GL_MODELVIEW);
glLoadIdentity();

glBindTexture(GL_TEXTURE_2D, frameTexture);
glGenerateMipmap(GL_TEXTURE_2D);

glBegin(GL_QUADS);
    glColor4d(1, 1, 1, 1);
    glTexCoord2d(0, 0); glVertex2d(0, 0);
    glTexCoord2d(1, 0); glVertex2d(width, 0);
    glTexCoord2d(1, 1); glVertex2d(width, height);
    glTexCoord2d(0, 1); glVertex2d(0, height);
glEnd();

camera.draw()只是操纵gls矩阵。 world.draw()函数使用视锥体剔除(从这里复制:http://nomis80.org/code/octree.html)迭代八叉树的节点(使用此实现:http://www.crownandcutlass.com/features/technicaldetails/frustum.html)并将叶子绘制为多维数据集。

draw gamegame->draw()函数打印。永远不会打印finished frame。看起来game->draw()函数递归调用显示函数,即使它在不同的文件中并且没有指向它的指针。是否可以使用代码存档此效果?这是mingw-g ++中的一个错误吗?

八叉树经常使用不安全函数reinterpret_cast。这可能是问题的根源吗?

我希望没有必要发布完整的源代码,因为它非常庞大。

1 个答案:

答案 0 :(得分:0)

这是一篇关于调试callstack损坏的有用文章http://hisham.hm/2012/02/14/debugging-a-stack-corruption-with-gdb/ 结果是取消引用悬空指针导致问题。