一只海星的主页

VS2017 程序在新电脑环境出现 “无法加载DLL “xxxx.dll”:找不到指定模块。”

背景

写了一个调用C++ DLL库的C#测试程序,在别人的电脑出现如下错误:

排查

  1. 确认自定义的DLL和需要引用的DLL在当前运行exe的同一目录。

  2. 确认是否按照VC运行库
    vc_redist.x64自己安装

  3. 确定运行库使用的环境 MT/MD

    /MT是 “multithread, static version ” 意思是多线程静态的版本
    /MD是 “multithread- and DLL-specific version” ,意思是多线程DLL版本

类似linux的lib/so,确保所有库都使用相同的运行库

终极大法

  1. depends
    dll依赖查看工具-depends

查找所有DLL依赖,更适合DLL缺省某函数逐一排查,我的测试程序N个DLL依赖,所以未果!

  1. dumpbin vs自带依赖查找工具

– 打开vs自带的CMD

– 跳转到exe运行目录
– 查找DLL所有依赖

dumpbin /dependents xxxx.exe #即可查询该exe的依赖项dll。
dumpbin /dependents *.dll  #查询所有依赖

接下来就是细心查找了
1. dumpbin /dependents *.dll命令列出所有DLL
2. 用Everything直接搜索拖动到当前exe目录,全部拷贝过来肯定能运行
3. 删除某个DLL再看能否运行
最终排查是缺少msvcr100.dll运行库!就是Windows的C库,vc_redist竟然没有包含!

至此Game over!

发表评论

邮箱地址不会被公开。 必填项已用*标注