gcc库的链接顺序导致编译出错的问题:
当一个库为基本库时,需要将该库放到引用它的库的后面进行链接,方能得到正确结果。
例如在OB中:
LDADD = $(top_builddir)/src/mergeserver/libmergeserver.a \
$(top_builddir)/src/common/libcommon.a \
$(top_builddir)/src/common/btree/libbtree.a \
${TBLIB_ROOT}/lib/libtbnet.a \
${TBLIB_ROOT}/lib/libtbsys.a
$(top_builddir)/src/common/libcommon.a \
$(top_builddir)/src/common/btree/libbtree.a \
${TBLIB_ROOT}/lib/libtbnet.a \
${TBLIB_ROOT}/lib/libtbsys.a
sys最基础,net、btree次之,最后才是mergerserver。
如果换成下面的顺序,将会出错,爆出大量的undefined reference:
LDADD = $(top_builddir)/src/mergeserver/libmergeserver.a \
${TBLIB_ROOT}/lib/libtbnet.a \
${TBLIB_ROOT}/lib/libtbsys.a
$(top_builddir)/src/common/libcommon.a \
$(top_builddir)/src/common/btree/libbtree.a \
${TBLIB_ROOT}/lib/libtbnet.a \
${TBLIB_ROOT}/lib/libtbsys.a
$(top_builddir)/src/common/libcommon.a \
$(top_builddir)/src/common/btree/libbtree.a \
原因:
GCC库链接顺序影响编译正确性
本文探讨了在GCC编译过程中,不同库的链接顺序对编译结果的影响,特别是当基本库位于依赖库之后时可能导致的编译错误。通过示例展示了正确的链接顺序确保编译成功的方法。
1万+

被折叠的 条评论
为什么被折叠?



