今天遇到了一个诡异的问题:编译通过,链接时候出错,提示:
./lib4//ccode/lib/libulccode.a(ul_ccode.o): In function `load_bj':
/home/search/libsource/build/ccode_4.0.0.0/ul_ccode.cpp:1634: undefined reference to `ul_fsize(char const*, char const*)'
/home/search/libsource/build/ccode_4.0.0.0/ul_ccode.cpp:1634: undefined reference to `ul_fsize(char const*, char const*)'
/home/search/libsource/build/ccode_4.0.0.0/ul_ccode.cpp:1644: undefined reference to `ul_readfile(char const*, char const*, void*, int)'
/home/search/libsource/build/ccode_4.0.0.0/ul_ccode.cpp:1655: undefined reference to `ul_readfile(char const*, char const*, void*, int)'又是一个典型的 “undefined reference to”类型的错误,后来发现问题出现在:
makefile中定义的-l 连接库的顺序不对,eg:
./test -lxxx -lyyy -lzzz
如果z中有调用xy的函数,就有可能会报错,要把被调用的写在后面,如:
./test -lzzz -lxxx -lyyy
我估计底层实现是用栈实现的参数读取,从右侧载入,所以会造成现在的问题。
本文讨论了一个常见的编译链接错误——未定义引用,并给出了一个实际案例。问题发生在特定的库文件链接顺序不当导致某些依赖未能正确解析。文章最后提出了正确的链接顺序解决方案。
&spm=1001.2101.3001.5002&articleId=7796475&d=1&t=3&u=d3065f5b0f244d9da66182bba24f26c3)
1万+

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



