当玩家四处走动时,我的服务器有时会崩溃。我尝试使用调试器运行它,但服务器出现错误:程序收到信号 SIGILL,非法指令。
它在 LogicHandler 中显示第 59 行。它的功能运行。这是该功能:
void LogicHandler::run()
{
try
{
unsigned short packetID = (packet->getGroup() * 666) + packet->getType();
switch (packetID)
{
case 666:
handleQuit();
break;
case 670:
handleLogin();
break;
case 672:
handleCreateCharacter();
break;
case 673:
handleDeleteActor();
break;
case 675:
handleSelectCharacter();
break;
case 1345:
handleMove(); <- HERE OCCURS SIGILL
break;
case 11332:
if(!connection.isLogged())
{
throw Poco::Exception("Unlogged access.");
}
connection.sendPing();
default:
if(!connection.isLogged())
{
throw Poco::Exception("Unlogged access.");
}
connection.sendPing();
break;
}
}
catch(...)
{
connection.shutdownConnection();
}
delete this;
}
这是调试器输出:
程序收到信号 SIGILL,非法指令。在 ??() ()
1 0x0040624d 在 F:\EternalHeroes\server\src\game\src\handler\LogicHandler.cpp:59 的 LogicHandler::run (this=0x3e9be0)
F:\EternalHeroes\server\src\game\src\handler\LogicHandler.cpp:59:1387:beg:0x40624d 在 F:\EternalHeroes\server\src\game\src\handler\LogicHandler.cpp:59
1 0x0040624d 在 F:\EternalHeroes\server\src\game\src\handler\LogicHandler.cpp:59 的 LogicHandler::run (this=0x3e9be0)
F:\EternalHeroes\server\src\game\src\handler\LogicHandler.cpp:59:1387:beg:0x40624d 继续... 程序收到信号 SIGILL,非法指令。在 ??() ()
1 0x0040624d 在 F:\EternalHeroes\server\src\game\src\handler\LogicHandler.cpp:59 的 LogicHandler::run (this=0x3e9be0)
F:\EternalHeroes\server\src\game\src\handler\LogicHandler.cpp:59:1387:beg:0x40624d 在 F:\EternalHeroes\server\src\game\src\handler\LogicHandler.cpp:59
1 0x0040624d 在 F:\EternalHeroes\server\src\game\src\handler\LogicHandler.cpp:59 的 LogicHandler::run (this=0x3e9be0)
F:\EternalHeroes\server\src\game\src\handler\LogicHandler.cpp:59:1387:beg:0x40624d 继续... [Inferior 1 (process 29040) exited with code 030000000035] 调试器以状态 0 完成