注1:为简洁起见,本文将assimp-vc140-mt.dll简称为assimp.dll,lib文件或其他版本(如assimp-vc142/143-mt/mtd.dll/lib)同理简称。
注2:本文对于已在项目配置-链接器-输入-附加依赖项 配置了assimp.dll而导致的链接器错误“LNK 1107:文件无效或损坏;无法在 0xXXX处读取;”也适用。将assimp.dll从附加依赖项中删除即可将问题转化为本问题。
环境:Windows 10 19044.2486
IDE:Visual Studio 2019 64bit
调试器目标架构:x64
错误表现:运行时报错:找不到“assimp-vc140-mt.dll”。
修复方案:打开项目属性-配置属性-调试-环境,按以下格式添加内容:
PATH=assimp-vc140-mt.dll所在路径;%PATH%
其中=后面应当是与读者所使用的assimp.lib版本相同的dll所在的路径。它通常在assimp主目录下某个层级的bin文件夹的x64或win32目录下。
方案分析:本方案之所以有效,其原理与其他常见的“将Assimp.dll复制到项目根目录或exe文件所在目录下”是一致的。都是保证程序运行时能正确链接到需要的依赖项assimp.dll。但本文提供的方法优势在于,通过修改项目配置设置,可以方便的在不同版本的依赖间切换,并且,不同的项目可以无需创建多个依赖文件的副本,通过路径直接链接到同一个文件,在多个项目需要依赖同一文件时不会占用额外空间。
问题:笔者仍不理解为何dll被作为输入文件记录在链接器附加依赖项中时,为何会触发LNK1107错误,理论上来说链接器可以处理dll文件,但在这个问题中,各个版本的assimp.dll以及预编译版本的assimp.dll均触发了这个错误,还请各路大佬不吝赐教,笔者将十分感谢。