最近开发几个插件,都是用的共享库,但是在加载共享库的时候,遇到了一些问题,这里记录一下。
1. 因为找不到依赖的动态库而加载失败
-
Windows 平台下,通常是因为运行环境和开发环境不同导致的。运行环境中缺少某些系统库,需要自己带上。在 Windows 下,可以使用 Dependency Walker 来查看共享库的依赖关系,然后将缺少的系统库拷贝到运行环境中。
-
Linux 平台下,通常是因为库的查找路径没有正确设置导致的。在 Linux 下,可以使用
ldd
命令来查看共享库的依赖关系,然后设置LD_LIBRARY_PATH
环境变量,让其可以找到依赖的共享库。 -
Macos 平台下,通常也是因为库的查找路径没有正确设置导致的。在 Macos 下,可以使用
otool -L
命令来查看共享库的依赖关系,然后设置DYLD_LIBRARY_PATH
环境变量,让其可以找到依赖的共享库。
2. 链接问题导致加载失败
最近遇到另外一个诡异的问题:一个函数拼写错误,编译时有个警告(被忽视了),链接居然通过了,但是加载该动态库失败,dlopen 失败,却没有错误提示。浪费不少时间后,才发现是这个问题。后来想重现这个问题时,却重现不了。不管怎么样,下次遇到类似问题,先修正编译警告中的问题。