更新时间:2017-08-17 12:25:28浏览次数:1+次
SIGSEGV错误,在Windows上对应的是内存访问错误,如空指针、内存越界等。而Linux中通常叫做Segment Fault,即段错误。这类问题通常都是由于内存访问出错。这个问题简直成了我写linux程序的阴影,原来不过如此。但是没有搞清楚之前,真是无尽的恐惧。
在POSIX兼容的平台上,SIGSEGV是当一个进程执行了一个无效的内存引用,或发生段错误时发送给它的信号。SIGSEGV的符号常量在头文件signal.h中定义。因为在不同平台上,信号数字可能变化,因此符号信号名被使用。通常,它是信号11。
之前在测试TCP服务器程序的时候,发现服务器程序在运行一段时间后,就被系统Kill了。通过跟踪coredump文件发现,是被signal 11 (SIGSEGV)信号所杀。也就是说,程序代码中哪里出现了内存访问错误或叫做指针使用错误。vector<int>::iterator it=g_client_list.begin();
for (;it!=g_client_list.end();++it)
{
//向所有客户端定期发送消息,维持客户端连接
int ret = srv.send(*it, (const char*)"is_alive\r\n", sizeof("is_alive\r\n"));
if (ret)
{
//发送失败,移除旧连接,客户端重新链接后会自动加入到客户端队列
g_client_list.erase(it);
it=g_client_list.begin();
}
}
Valgrind提示错误发生在erase()函数。通过分析后,才恍然大悟。下面是一段检测问题的代码:
vector<int>::iterator it = g_client_list.begin();
for (; it != g_client_list.end(); ++it)
{
if(it== g_client_list.begin())
printf("it等于开始");
if (it == g_client_list.end())
printf("it等于结束");
if (it == g_client_list.end()+1)
printf("it等于结束+1");
//向所有客户端定期发送消息,维持客户端连接
int ret = srv.send(*it, (const char*)"is_alive\r\n", sizeof("is_alive\r\n"));
if (ret)
{
//发送失败,移除旧连接,客户端重新链接后会自动加入到客户端队列
g_client_list.erase(it);
it = g_client_list.begin();
}
}
可以检测到,当客户端断开后,打印了“it等于结束+1”,自然it就不等于end(),for的判定条件就会通过,然后就出现内存越界了。
相关资讯