cstring.format
这段时间一直在忙项目,也没有时间来博客把这段时间的东西整理下粘贴上来,只是今天晚上把手上的工作调试完成了,上了博客才决定把今天遇到的问题发上来供大家参考。
今天一天都在编代码,作调试,到晚上才发现以前的项目中的代码存在问题,但是以前为什么就好好的呢?真是想不通,在调试的过程中,由于主框架程序调用了我自己封装的一个采集模块组件,这个组件采用mfc dll封装成COM的形式进行调用,但是在主框架程序中调用这个模块老是有问题,在显示采集模块窗口界面的时候就出现“Expression Buffer too small"的错误提示,搞得非常郁闷,调试都没有办法进行,于是上网查找了下,说可能是CString::Format这个函数出现的问题,于是我仔细的查看了代码,结果发现在窗口界面的初始化OnInitDialog函数中有下面的这句代码:
m_strFBL.Format("%s(放大约%d倍)", m_strFBL, m_nfbl / m_nScreenDPI);
Format中的参数为m_strFBL字符串本身,我估计是Format在内部根据格式化参数列表会对字符串本身的内存空间进行重新分配,而如果直接采用字符串本身作为参数传入的话,这个过程中就会造成内存的冲突,而这个冲突是无法预见的,查看了下msdn,微软也作了相应的注释:
The call will fail if the string object itself is offered as a parameter to Format. For example, the following code:
CString str = "Some Data";
str.Format("%d%d", str, 123); //Attention: str is also used in the parameter list.
will cause unpredictable results.
所以为了避免这种无法预见的问题,我们最好不要采取将字符串本身作为参数作为Format的参数,可以另外定义一个CString变量:
CString str;
str.Format(Format("%s(放大约%d倍)", m_strFBL, m_nfbl / m_nScreenDPI);
这样问题就解决了。