静态库之间的连接关系

时间:2023-01-05 19:34:06

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文件。

  
  
  
  1. gcc -c func.c  
  2. gcc -c test.c  
  3. gcc -c main.c 

    然后,将test.c和func.c各自打包成为静态库文件。

  
  
  
  1. ar –rc func.a func.o  
  2. ar –rc test.a test.o 

    这时,我们准备将main.o链接为可执行程序,由于我们的main.c中包含了对test()的调用,因此,应该在链接时将test.a作为我们的库文件,链接命令如下。

  
  
  
  1. gcc -o main main.o test.a 

    这时,编译器仍然会报错,如下:

  
  
  
  1. test.a(test.o): In function `test':  
  2. test.c:(.text+0x13): undefined reference to `func'  
  3. collect2: ld returned 1 exit status 

    就是说,链接的时候,发现我们的test.a调用了func()函数,找不到对应的实现。由此我们发现,原来我们还需要将test.a所引用到的库文件也加进来才能成功链接,因此命令如下。

  
  
  
  1. gcc -o main main.o test.a func.a 

    ok,这样就可以成功得到最终的程序了。同样,如果我们的库或者程序中引用了第三方库(如pthread.a)则同样在链接的时候需要给出第三方库的路径和库文件,否则就会得到undefined reference的错误。