问题描述
最近尝试链接一个自行构建的c语言共享库到本地项目时,遇到链接错误,提示“未定义的引用”。错误信息如下:
排查过程
尝试多次重新编译库,并尝试了不同的方法,均无效。在搜索引擎上查找相关信息后,发现一个论坛中有人遇到类似问题,但使用的是32位工具链,而我的工具链是64位的。 排除了工具链版本差异后,考虑尝试不同的编译器。
解决方案
最初使用gcc编译,切换到clang后,问题解决。
问题复现及分析
为了理解问题根源,创建了一个简单的测试项目:
- lib.h:
- lib.c:
- main.c:
- build_so.sh (clang编译共享库):
- build_main.sh (gcc编译主程序,链接共享库):
使用上述脚本,链接失败,出现类似的“未定义引用”错误:
然而,如果将build_so.sh和build_main.sh中的编译器互换(即使用gcc编译共享库,clang编译主程序),则链接成功。
结论
该问题可能与编译器之间在生成和链接共享库时的内部符号处理方式差异有关。 在使用不同编译器构建共享库和可执行文件时,需要确保两者兼容。 虽然在大多数情况下,使用同一编译器可以避免此问题,但本例说明了不同编译器之间潜在的兼容性问题。 如果项目中需要使用不同编译器,则需要仔细检查并确保它们之间能够正确地进行符号解析。
以上就是独特的共享库问题的详细内容,更多请关注代码网其它相关文章!
发表评论