最近编译了一个库,我用的/MD选项,得到的dll依赖msvcr80.dll。
我写了一个测试程序,去调用上面我编译好了的dll。可是我用的/MDd开关去编译我的测试程序。编译是通过了,运行却出现了错误。最后仔细想了想,是msvcr80.dll和msvcr80d.dll这2个dll在同一进程中的共存问题。
要解决,只需要将我的测试程序用/MD编译,和我编译的库一样,都去指向msvcr80.dll。要么都使用/MDd (都指向msvcr80d.dll),要么都使用/MD (都指向msvcr80.dll)。
结论:对于微软提供的crt运行库,一般都提供2个版本,debug和release,在编译的时候对应/MDd和/MD选项。对于80版本的crt dll,有msvcr80d.dll和msvcr80.dll这个2个dll对应。一个可执行文件依赖很多dll文件,其中可能会有msvcr80.dll这样的依赖文件,如果依赖文件列表中还有msvcr80d.dll,那么win系统在加载可执行文件的时候就会出错。至于什么原因出错,还得问微软。
也许微软就是要给我们强规定,对于一套我们微软发布的crt dll(此文说的不针对静态链接,即/MTd 和 /MT选项。),如果客户要使用这套crt dll,在自己程序中,对dll文件的应用要么是调试版本的(msvcr80d.dll),要么是发布版本的(msvcr80.dll)。