记录OCI操作一个诡异的问题
今天稍微改了下主线版本的代码,不知从何时起,后台关闭会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& trim(std::string &s)
- {
- if (s.empty())
- {
- return s;
- }
- s.erase(0,s.find_first_not_of(" "));
- s.erase(s.find_last_not_of(" ") + 1);
- return s;
- }
换成另外一个实现问题就没出现了:
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);
}