问题描述: 使用VS2005在Windows Server 2003上编译C++代码, 输出dll文件, 把该dll放到运行机器(与编译机器的系统完全一致)上, 供C#代码(web前台)调用, 提示无法加载dll.
分析:
1. 路径完全没有问题, dll放置在应用程序的启动目录.
2. 经过查阅资料发现, 有可能是该dll依赖于另一个dll, 而另一个dll不存在.
我使用MD选项(项目属性->配置属性->C/C++->代码生成->运行时库)编译dll的, MD表示多线程动态链接(使用运行时库). 使用Dependency Walker工具查看dll文件的依赖, 发现有两个依赖找不到:MSVCR80.DLL和IESHIMS.DLL. 其中的第一个依赖MSVCR80.DLL是VC的运行时库,
解决方案1: 如果在运行机器上安装VS2005(或者把该依赖DLL复制过去), 该问题肯定可以解决. 更简单的方法是第二个方案.
解决方案2: 使用静态链接编译dll, 将MD选项改为MT. 使用MT选项生成的dll文件大小更大, 使用Dependency Walker发现生成的dll不再依赖MSVCR80.DLL.