问题描述
一个很简单的函数:
void do_print(const char *format_str,int arg)
{
std::map<std::string,std::string> data_map;
char buff[102400]={0};
....
printf(format_str,arg);
}
这个函数引起了The inferior stopped because it triggered an exception错误,错误的提示里面还有 stack over_flow这样的字眼。
通过调试发现,进入到这个函数之前,参数都是好的,一进入到这个函数,
format_str,arg都是NULL。
有时会崩在std::mapstd::string,std::string data_map;这一句上。
原因
首先确认过,这个文件很久没有改动过了,所以应该不是代码的问题。
而且代码的逻辑也十分简单。
通过分析,发现可能是程序的堆栈小了,于是Vs的项目属性->Linker->系统->堆栈保留大小,将堆栈调大,就不会崩溃了。
个人猜测是我这个函数执行之前,就有多层其他函数调用,而且
其他函数有处理数据包等动作,也会在栈上申请内存,从而导致
默认的1MB堆栈不够用了。