有时候线程会出现SIGPIPE错误:
(gdb) bt
#0 0x00110416 in __kernel_vsyscall ()
#1 0x0092f918 in send () from /lib/libpthread.so.0
这是因为在调用socket发送函数send()时,出现的异常错误,可能的原因是因为tcp连接可能不正常,导致了send()数据失败,系统会收到SIGPIPE信号,
(gdb) bt
#0 0x00110416 in __kernel_vsyscall ()
#1 0x0092f918 in send () from /lib/libpthread.so.0
这是因为在调用socket发送函数send()时,出现的异常错误,可能的原因是因为tcp连接可能不正常,导致了send()数据失败,系统会收到SIGPIPE信号,
系统默认的处理是退出进程。可以让系统屏蔽SIGPIPE信号,这样服务端进程就不会异常退出了,可以继续运行。
1.在main函数一开始执行下面的屏蔽SIGPIPE信号:
signal(SIGPIPE, SIG_IGN);
2. 但在线程中还是会出现SIGPIPE问题,添加下面的代码,屏蔽线程中的SIGPIPE信号:
sigset_t signal_mask;
sigemptyset (&signal_mask);
sigaddset (&signal_mask, SIGPIPE);
int rc = pthread_sigmask (SIG_BLOCK, &signal_mask, NULL);
if (rc != 0)
{
printf("block sigpipe error\n");
}
上面的代码应写在main函数的开头,创建线程之前。
问题解决。
转自:http://blog.csdn.net/doctorllm/article/details/43410027