前言----------------------------------
最近工作中遇到一个linux编译问题,其实是小问题,但经验不足,弄了2天,特做记录。
背景---------------------------------
这次是做一个新的项目,项目软件编译架构如下图:
|-----libm1.a |-----libn1.a
main-----|-----libm2.a -------|
|-----libm3.a |------libn2.a
说明:主程序下有三个模块m1、m2、m3,其中模块m2依赖开源模块n1和n2,模块n1依赖n2.
编译时是在主makefile里包含所有的子makefile,包括m1、m2、m3、n1和n2的makefile,链接时把所有的静态库链接成一个可执行程序。
问题--------------------------------------
编译到最后所有的静态库都生产了,但是在链接时,报错链接libm2.a的时候报错,类似“func_xxx() 未定义的引用”。
这些func_xxx()都是定义在libn1.a和libn2.a里的函数,并且在libm2.a里面被调用了。
原因应该是链接libm2时找不到这些函数的实现。
解决方法---------------------------------
调整链接的顺序即可,之前的链接顺序是:
LIBS += $(REL_LIB_DIR)/libn1.a
LIBS += $(REL_LIB_DIR)/libn2.a
LIBS += $(REL_LIB_DIR)/libm2.a
调整后为:
LIBS += $(REL_LIB_DIR)/libm2.a
LIBS += $(REL_LIB_DIR)/libn1.a
LIBS += $(REL_LIB_DIR)/libn2.a
总结----------------------------------------------
这个问题是链接时找不到依赖函数的实现,原因是链接时依赖顺序不对。
之前做的比较多的是android的makefile,android里面的链接顺序写法是把被依赖的库写在前面,而linux里面刚刚相反了。