转:跨dll操作fopen的返回值导致出错

从老板的blog那里抄来的,一个很神奇的bug,雷死:

源地址http://www.cnblogs.com/len3d/p/3406294.html

在设置成/MD 或 /MDd 不会导致出错

设置成/MT 或 /MTd 的情况下会导致出错

看了CRT的实现,估计是因为fopen创建了CriticalSection来保护文件,但是在/MT的情况下,一个DLL里面的CriticalSection是不能被另外一个DLL使用的。

 

只是猜测啊。。。。。。。。。。。。。。。

 

看了VS2008 里的crt 源码,发现_iob这个全局变量,

而每个操作FILE指针的函数都要,操作这个变量处理多线程的功能

而MD模式 把crt库编译到同一个静态库里面,所以不会出现bug

而MTd模式 把crt库编译到相应的dll文件,导致在调用操作FILE指针的函数在 比对 _iob时使用的是不同的堆栈数据,导致bug产生

解决方案:不要跨dll使用fopen 全部工程使用MD 模式

posted on 2013-12-03 20:43  Wen tao.Wang  阅读(356)  评论(0编辑  收藏  举报

导航