[编译]GCC 连接顺序

当使用两个静态库存在依赖的时候,连接的时候可能会遇”undefined reference to”问题。
这里我们使用a.c b.c main.c 来说明:

// acall.h
#ifndef __ACALL_H__
#define __ACALL_H__
int acall( int a, int b);
#endif
// bcall.h
#ifndef __BCALL_H__
#define __BCALL_H__
#include "acall.h"
int bcall( int a, int b);
#endif
// acall.c
int acall( int a, int b)
{
    return a+b;
}
// bcall.c 
#include "bcall.h"
int bcall( int a, int b)
{
    return acall( a, b);
}
// main.c 
#include 
#include "bcall.h"
int main()
{
    printf("==>%d\n", bcall( 2,3));
    return 0;
}

编译连接:

    gcc -g -fPIC -c acall.c -o a.o
    gcc -g -fPIC -c bcall.c -o b.o
    gcc -g -c main.c -o main.o
    ar r liba.a a.o
    ar r libb.a b.o
    gcc main.o -o main -la -lb -L.
编译报错:
    ./libb.a(b.o): In function `bcall':
    bcall.c:4: undefined reference to `acall'
    collect2: error: ld returned 1 exit status

这是因为连接的时候寻找函数的symbol link 是从左向右的库里面搜索。因此需要修改编译指令为:
gcc main.o -o main -lb -la -L.
同时,GCC提供了额外的编译选项 -Xlinker用于解决不清楚依赖关系下的库编译,使用方式如下:
gcc -o main6 main.o -Xlinker "-(" liba.a libb.a -Xlinker "-)" -L.

参考链接:库的链接顺序 http://www.cppblog.com/findingworld/archive/2008/11/09/66408.html

你可能感兴趣的:(编译原理)