1:静态库之间的连接关系:
要使用一个静态库,必须要有头文件,就可以直接调用;如果一个静态库依赖另外一个静态库时,只要把两个静态库放在一起,系统会自动链接;
例如:我们可以编译一个静态库,使用,一个.h和一个cpp,一个静态库以及静态库的头文件,就可以生成两个静态库,最后发布版本的时候,只要一个.h文件和.a就可以了,不需要依赖库的头文件!
2:动态库的使用依赖关系:
依赖的动态库,必须存在,使用和静态库差不多,需要头文件和动态库,已经依赖的动态,不需要依赖库的头文件;
3:出现undefined reference to" 问题解决方法,这种问题比较隐蔽,也是我最近遇到的与网上大家讨论的不同的问题,举例说明如下,首先,还是看看测试代码。当依赖多个库的时候,要注意静态库的依赖顺序。
从上图可以看出,main.c调用了test.c的函数,test.c中又调用了fun.c的函数。
首先,我们先对fun.c,test.c,main.c进行编译,生成 .o文件。
- gcc -c func.c
- gcc -c test.c
- gcc -c main.c
然后,将test.c和func.c各自打包成为静态库文件。
- ar –rc func.a func.o
- ar –rc test.a test.o
这时,我们准备将main.o链接为可执行程序,由于我们的main.c中包含了对test()的调用,因此,应该在链接时将test.a作为我们的库文件,链接命令如下。
- gcc -o main main.o test.a
这时,编译器仍然会报错,如下:
- test.a(test.o): In function `test':
- test.c:(.text+0x13): undefined reference to `func'
- collect2: ld returned 1 exit status
就是说,链接的时候,发现我们的test.a调用了func()函数,找不到对应的实现。由此我们发现,原来我们还需要将test.a所引用到的库文件也加进来才能成功链接,因此命令如下。
- gcc -o main main.o test.a func.a
ok,这样就可以成功得到最终的程序了。同样,如果我们的库或者程序中引用了第三方库(如pthread.a)则同样在链接的时候需要给出第三方库的路径和库文件,否则就会得到undefined reference的错误。