昨天上车自测本模块功能稳定性,顺便pull小弟分支,帮忙一起验证。结果小包上车后无法运行,一查发现一直报
undefined symbol: XXXXXX
晚上下班后开始帮忙排查。今日记录以便后期回顾。
前两年写过一篇关于undefined symbol 问题的排查贴,但发生undefined symbol的情况有多种,一篇不足以盖全。
报错分析
undefined symbol 为 符号未定义,意味着程序的符号表中找不到这个符号。符号表是什么这里就简述一下不多说了,感兴趣可以去看一下编译原理(有空我也研究一下写个专栏博,hhh)。
先简单了解一下编译过程:
简述一下符号表的含义和作用:
在链接后,代码中的各种符号(函数、变量等)都被分配了地址,并将信息记录在符号表中。
例如:
存在一个函数 void function(int x) ,系统先在内存上分配一块内存,设地址为10010,再将函数标识符function、void关键字标识符和地址10010等信息记录到符号表中。
当符号被使用时,系统会去符号表里查询地址,通过查询到的地址去获取相应的信息来使用。
解决办法
通常undefined symbol的发生有两种情况:
-
找不到依赖的动态库
这种需要看一下自己的makefile或者动态库配置文件,动态库名字或者路径是否有问题、调用的库版本是否正确