Makefile的链接顺序
在链接静态库时,如果静态库之间存在依赖关系,则存在依赖关系的静态库在链接时存在链接顺序的问题,否则会出现找不到链接符号的错误,undefined reference to `XXX'.
例如:libtest2.a依赖libtest1.a,可执行文件test依赖libtest2.a,则链接顺序为:-llibtest2.a -l libtest1.a,而不能反过来,否则会出现链接错误,某些符号找不到。多个.o文件链接成可执行文件的时候。如果链接的顺序不对,会产生错误。
如果存在循环依赖,例如A依赖B,B又依赖A,那么链接的时候,需要存在告诉连接器去多次搜索例如ABA 或者BAB的情况。这种设计是非常糟糕的。所以在写程序的时候,动态库之间的依赖,尽量要写成垂直依赖关系。
在链接的时候,建议顺序如下,越是底层的库,越往后面放:
g++ ... obj($?) -l(上层逻辑lib) -l(中间封装lib) -l(基础lib) -l(系统lib) -o $@
拓展:--start-group和--end-group
放在这两个地方的库会自动解决依赖,