标签:signal sign dmp size_type crash 输出 date find errno
今天稍微改了下主线版本的代码,不知从何时起,后台关闭会crash掉,报错如下:
ORA-24550: signal received: [si_signo=6] [si_errno=0] [si_code=-6] [si_int=0] [si_ptr=(nil)] [si_addr=0x3ec00003fb5]
kpedbg_dmp_stack()+362<-kpeDbgCrash()+192<-kpeDbgSignalHandler()+119<-skgesig_sigactionHandler()+218<-__sighandler()<-gsignal()+55<-malloc_consolidate()+1029
仔细检查代码,并未改动和oci操作相关的代码,只是加了一些日志输出的内容,经过仔细排查对比发现是由于
使用了网上一段字符串trim的代码导致:
换成另外一个实现问题就没出现了:
std::string str_trim(std::string &str)
{
????string::size_type pos = str.find_first_not_of(‘ ‘);
????if (pos == string::npos)
????{
????????return str;
????}
????string::size_type pos2 = str.find_last_not_of(‘ ‘);
????if (pos2 != string::npos)
????{
????????return str.substr(pos, pos2 - pos + 1);
????}
????return str.substr(pos);
}
标签:signal sign dmp size_type crash 输出 date find errno
原文地址:http://www.cnblogs.com/skiing886/p/7927892.html