前几天程序新加一个功能之后,其中用到了boost的lexical_cast<float>,发现在关闭命令行窗口的时候,程序报错,是程序退出清理时候报的错误。
一开始以为是程序新增的功能有问题,发现去除新功能之后,随便在一个函数中使用lexical_cast<float>,程序在退出的时候都会报错。
所以怀疑是自己程序功能异常,包括可能的堆栈异常,针对lexical_cast<float>部分的数据内存都进行了检查,都没有问题。而且将lexical_cast<float>换成atof之后,程序关闭退出也是正常的。
后来开始google相关的内容,发现应该是vs2012在Debug模式下,将new和free都替换成了自己重新定义的函数,导致lexical_cast<float>中使用的std::numpunct在创建的时候使用的是new,在释放的时候使用的是free,所以出现程序退出时函数堆栈异常。
相关的链接https://code.google.com/p/chromium/issues/detail?id=107567,这个是针对std::numpunct释放时堆栈异常问题的讨论
https://connect.microsoft.com/VisualStudio/feedback/details/502037/crash-in-vc100-crt-on-application-exit-debugheapdelete是关于vs2010程序退出堆栈异常bug的讨论。
幸运的是,这个问题在centOS的gcc环境下是不存在这个问题的,程序退出时使用valgrind监控,并没有任何的错误报告。
不过有点让我疑惑的是,如果只建立一个简单的项目其中直接使用lexical_cast<float>,在程序退出时是没有报错的,其中可能还有我目前没有找到的原因所在。