5

现在我有 3 个共享对象,A.so,B.so,C.so

    A.c    
    void libA()  
    {  
        common();  
    }  

    B.c
    void common()  
    {  
        printf("COME HERE B\n");  
    }  

    C.c
    void common()  
    {     
        printf("COME HERE C\n");  
    }  
    (just ingore the .h files)

    test.c
    int main()  
    {  
      libA();    
      return 1;  
    }  

complie:  
gcc -fPIC -shared libB.so libB.c  
gcc -fPIC -shared libA.so libA.c ./libB.so  
gcc -o test test.c libC.so libA.so  

我希望结果是“COME HERE B”,我可以dlopenRTLD_DEEPBIND标志一起使用,
但是在我的项目中将函数从隐式调用更改为显式调用会花费太多时间。
有没有办法解决这个问题?

gcc -Wl,-Bsymbolic在此解决方案中不起作用。

好吧,如果 Ac 包含 common 的实现。它确实有效。

4

1 回答 1

1

看起来当动态链接器在运行时搜索一个符号时,它会选择它遇到的第一个。搜索顺序取决于DT_NEEDED二进制部分中库的顺序,而这又取决于编译期间命令行中库的确切顺序。因此,请确保在编译时位于命令行libB.so之前。libC.sotest.c

于 2015-01-11T22:38:29.170 回答