我正在开发基于客户端-服务器图块的游戏。客户端保存 3 维数据,std::vector
并在每一帧中将其内容与服务器发送的内容进行比较(我std::vector
在客户端有一个单独的内容,其中填充了服务器发送的数据)。
现在客户端的地图由 15x11 个图块组成,每个图块包含大约 10 个放置在其上的对象的数据,所以我在 a 中得到 15*11*10 = 1650 个元素 std::vector
。
我正在比较两个std::vector
s 中的数据,如果有变化,我会创建新对象/删除对象/移动对象,具体取决于差异。我就是这样做的:
std::vector<IdAndPosition> clientIds;
std::vector<IdAndPosition> serverIds;
// Fill client ids
for(unsigned int i = 0; i < m_tiles.size(); i++)
{
for(unsigned int j = 0; j < m_tiles[i].size(); j++)
{
for(unsigned int s = 0; s < m_tiles[i][j].getObjects().size(); s++)
{
clientIds.push_back(IdAndPosition(m_tiles[i][j].getObjectAtPosition(s)->getId(), i, j, s));
}
}
}
// Fill server ids
for(unsigned int i = 0; i < g_gameStateData.m_gameObjects.size(); i++)
{
for(unsigned int j = 0; j < g_gameStateData.m_gameObjects[i].size(); j++)
{
for(unsigned int s = 0; s < g_gameStateData.m_gameObjects[i][j].size(); s++)
{
serverIds.push_back(IdAndPosition(g_gameStateData.m_gameObjects[i][j][s].second, i, j, s));
}
}
}
for (int i = 0; i < serverIds.size(); i++)
{
IdAndPosition& serverId = serverIds[i];
bool found = false;
for(int j = 0; j < clientIds.size(); j++)
{
IdAndPosition& clientId = clientIds[j];
found = serverId.id == clientId.id;
if(found)
break;
}
if(!found)
{
// If not found, create that object
// tileX // tileY
m_tiles[serverId.pos[0]][serverId.pos[1]].addObjectAtPosition(
TGameObjectFactory::createGameObject(g_gameStateData.m_gameObjects[serverId.pos[0]][serverId.pos[1]][serverId.pos[2]].first), // Game object
serverId.pos[2] // Position at stack
);
// And set it's individual id
m_tiles[serverId.pos[0]][serverId.pos[1]].getObjectAtPosition(serverId.pos[2])->setId(g_gameStateData.m_gameObjects[serverId.pos[0]][serverId.pos[1]][serverId.pos[2]].second);
}
}
for (int i = 0; i < clientIds.size(); i++)
{
IdAndPosition& clientId = clientIds[i];
bool found = false;
for(int j = 0; j < serverIds.size(); j++)
{
IdAndPosition& serverId = serverIds[j];
found = serverId.id == clientId.id;
if(found)
break;
}
if(!found)
{
// If not found, create empty object at this position
// tileX // tileY
m_tiles[clientId.pos[0]][clientId.pos[1]].addObjectAtPosition(
TGameObjectFactory::createGameObject(NO_GAME_OBJECT_ID), // Empty game object (we're removing deprecated one)
clientId.pos[2] // Position at stack
);
}
}
问题是由于在调试模式下调用该函数(从 ~90 到 ~20 fps),我的性能大幅下降。我知道每帧都要经过大量数据,但我不知道如何设计它以使其不那么慢。
我在 Visual Studio 2012 中使用了性能分析来找出导致最大性能下降的确切原因,我得到了这个结果:
所以看起来[] operator
是std::vector
主要原因。