现在我有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
Run Code Online (Sandbox Code Playgroud)
我希望结果是"来这里B",我可以用dlopen用RTLD_DEEPBIND标志,
但它的成本太多时间从隐式调用函数改变成显式调用在我的项目.
反正有没有解决这个问题?
gcc -Wl,-Bsymbolic 在此解决方案中不起作用.
好吧,如果Ac包含普通的实现.它确实有效.