我有一个应用程序可以使用在运行时使用 dlopen 加载的插件。每个插件都定义了一个函数来检索使用通用结构定义的插件信息。像这样的东西:
struct plugin {
char *name;
char *app_version;
int app_verion_id;
char *plugin_version;
int plugin_version_id;
/* ... */
};
struct plugin p = { "sample plugin",APP_VERION,APP_VERSION_ID,"1.2.3",10203 };
struct plugin *get_plugin() {
return &p;
}
这很好用,可以加载插件。现在我想构建一个小工具来读取这些属性而不链接整个应用程序。为此,我有一些这样的代码:
void *handle;
struct plugin *plugin;
struct plugin *(get_plugin*)();
handle = dlopen(filename, RTLD_LAZY);
if (!handle) { /*...return; ...*/ }
get_plugin = dlym(handle, "get_plugin");
if (!get_plugin) { /*...return; ...*/ }
plugin = get_plugin();
printf("Plugin: %s\n", plugin->name);
这适用于简单的插件。问题是许多插件引用了应用程序中的更多符号,即使设置了 RTLD_LAZY,这些符号也得到了解决。(就像应用程序中用于初始化插件全局事物的全局变量)所以 dlopen() 调用失败并出现类似fatal: relocation error: file sample_plugin.so: symbol application_some_symbol: referenced symbol not found
. 因为我只想访问单个简单结构,所以我想知道如何阻止链接器完成他的大部分工作。