
问题描述
最近尝试链接一个自行构建的C语言共享库到本地项目时,遇到链接错误,提示“未定义的引用”。错误信息如下:
/bin/ld: /tmp/cchb7mj8.o: in function `sdl_main': main.c:(.text+0x3c): undefined reference to `sdl_enterappmaincallbacks' ... (其他类似的未定义引用) ... collect2: error: ld returned 1 exit status make: *** [makefile:7: all] error 1
排查过程
尝试多次重新编译库,并尝试了不同的方法,均无效。在搜索引擎上查找相关信息后,发现一个论坛中有人遇到类似问题,但使用的是32位工具链,而我的工具链是64位的。 排除了工具链版本差异后,考虑尝试不同的编译器。
解决方案
最初使用GCC编译,切换到Clang后,问题解决。
问题复现及分析
1.修正BUG站用资源问题,优化程序2.增加关键词搜索3.修改报价4.修正BUG 水印问题5.修改上传方式6.彻底整合论坛,实现一站通7.彻底解决群发垃圾信息问题。注册会员等发垃圾邮件7.彻底解决数据库安全9.修改交易方式.增加网站担保,和直接交易两中10.全站可选生成html.和单独新闻生成html(需要装组建)11. 网站有10中颜色选择适合不同的行业不同的颜色12.修改竞价格排名方式13.修
为了理解问题根源,创建了一个简单的测试项目:
- lib.h:
#pragma once int add(int a, int b);
- lib.c:
#include "lib.h"
int add(int a, int b) {
return a + b;
}
- main.c:
#include "lib.h" #includeint main () { printf("4+3=%d\n", add(4, 3)); return 0; }
- build_so.sh (Clang编译共享库):
clang -std=c11 -c -o lib.o lib.c clang -shared -fpic -o libm.so lib.o
- build_main.sh (GCC编译主程序,链接共享库):
gcc -std=c11 -L. -l:libm.so main.c -o main
使用上述脚本,链接失败,出现类似的“未定义引用”错误:
/bin/ld: /tmp/ccymm8ki.o: in function `main': main.c:(.text+0x13): undefined reference to `add' collect2: error: ld returned 1 exit status
然而,如果将build_so.sh和build_main.sh中的编译器互换(即使用GCC编译共享库,Clang编译主程序),则链接成功。
结论
该问题可能与编译器之间在生成和链接共享库时的内部符号处理方式差异有关。 在使用不同编译器构建共享库和可执行文件时,需要确保两者兼容。 虽然在大多数情况下,使用同一编译器可以避免此问题,但本例说明了不同编译器之间潜在的兼容性问题。 如果项目中需要使用不同编译器,则需要仔细检查并确保它们之间能够正确地进行符号解析。









