我试图使这个OSX代码(golfed为便于讨论)在Ubuntu Linux上工作。兄弟之间的.so文件中的符号的可见性
cat >main.c <<EOF
#include <stdio.h>
#include <stdlib.h>
#include <dlfcn.h>
void provided_by_main() { puts("Hello main!"); }
int main() {
void *provider_so, *needer_so;
(provider_so = dlopen("provider.so", RTLD_NOW)) || printf("Fail %s\n", dlerror()) && (exit(0),0);
(needer_so = dlopen("needer.so", RTLD_NOW)) || printf("Fail %s\n", dlerror()) && (exit(0),0);
void (*needer)() = dlsym(needer_so, "needer");
needer();
}
EOF
cat >needer.c <<EOF
extern void provider();
void needer() { provider(); }
EOF
cat >provider.c <<EOF
#include <stdio.h>
void provider() { puts("Hello provider!"); }
EOF
gcc -shared -o provider.so provider.c
gcc -shared -o needer.so needer.c -dynamic -undefined dynamic_lookup
gcc -o main main.c -ldl
./main
Hello provider!
在Linux上,通过试错和StackOverflow上,我决定needer
不能引用在main
定义的任何东西,除非main
已经与-rdynamic
链接:
gcc -shared -fpic -o provider.so provider.c
gcc -shared -fpic -o needer.so needer.c -Dprovider=provided_by_main
gcc -o main main.c -ldl -rdynamic
./main
Hello main!
但是,我不能让needer
到即使整个“链”编译为-rdynamic
:
gcc -shared -fpic -o provider.so provider.c -rdynamic
gcc -shared -fpic -o needer.so needer.c
gcc -o main main.c -ldl -rdynamic
./main
Fail needer.so: undefined symbol: provider
0见
provider
提供的任何东西
那么,我该如何做这项工作?
或者,如果在设计上Linux是不可能的,那么为什么被设计为不可能?
(OSX相当于:Accessing main program global variables from a dlopen()ed dynamic library in C on OS X)
真实世界的奖金并发症:在我实际的程序,provider.so
是代码生成在运行时,并没有确定provider
符号的名称,直到main
有后被链接。但是,即使涉及修改main.c
的答案也是朝正确方向迈出的一步。
谢谢! :D(我已编辑您的评论以包含剪切和粘贴的代码。) – Quuxplusone