c++ - 当这些对象位于单独的共享库中时,如何向工厂自动注册 C++ 对象?

标签 c++ shared-libraries registration factory

我的情况是,我想创建一个包含工厂的库,我们称它为 FooFactory,对于来自公共(public)基类的派生类,我将其称为 IFoo。然后我有各种对象 Foo1、Foo2 等,它们派生自 IFoo,但在单独的共享库中声明。

当 Foo1、Foo2 等在同一个库中时,我可以定义静态全局对象 InitializeFoo1、InitializeFoo2 等,在它们的构造函数中,向工厂注册该类的创建方法。但是,当它们位于单独的库中时,这些初始化对象永远不会被实例化,因此派生类永远不会被注册。

我之前的研究表明,如果这些库是静态链接的,否则从未使用过,初始化程序可能会被删除,并且它们的构造函数也不会被调用,但共享库也是这种情况吗?如果是这样,是否有某种方法可以确保这些初始化对象被实例化?最后,如果我只是“把这一切都搞错了”,我当然愿意接受任何关于更好的方法的建议。

我还应该注意,这个问题出现在路上 here .在那种情况下,对原始问题的建议答案暗示了这样的静态初始化程序对象,但发问者评论说它不起作用的原因与我的原因相同——初始化程序从未实例化——但这个评论基本上没有得到解决。

一些上下文:这一切都发生在 Linux 机器上,我正在使用 gcc 4.7.3 进行编译。万一它有帮助,这样做的原因是允许开发人员创建新的派生对象,并且可以将其链接到代码中而无需修改或重新编译现有代码库。 (新对象是根据运行时事件创建的。)

最佳答案

我用 gcc 4.1.2 测试了你在 RHEL 5.7 上描述的情况,当在共享库中定义时,全局静态也会被构造。如果 main 使用 g++ -l lib 选项与共享库链接,那么构造函数将按预期在 main() 之前被调用,并且如果 lib 是手动加载的使用 dlopen() 调用,然后自然会在加载 lib 时构造它。但在这两种情况下它都是自动构建的。

无论如何,也许作为一种解决方法,您可以为共享库定义一个“构造函数”,即在加载库时由系统调用的函数,并将您的初始化对象定义为函数中的静态对象?其语法如下:

extern "C" {

void __attribute__ ((constructor)) libload(void)
{
    cout << "dll ctor called\n";
    static A a;
}

void __attribute__ ((destructor)) libunload(void)
{
}

} // extern

关于c++ - 当这些对象位于单独的共享库中时,如何向工厂自动注册 C++ 对象?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20932744/

相关文章:

python - 使用mingw调试STL容器,python脚本问题

c++ - OpenGL ES 2 如何渲染到纹理和提取数据用于 GPGPU 测试

c++ - Linux 相当于 DllMain

PHP/MySQL 注册表未检测密码

c# - .NET中的注册页面错误

c++ - 从另一个结构中的函数返回结构的困难

c++ - #include 在 C++ 枚举中的效果

java - 在 Java 中为 Android 开发时 "shared library"究竟意味着什么? (`*.jar` 或 `*.so`)

linux - 跨不同机器共享主目录的解决方案 - 更改 $HOME 变量?

php - 如何修复我的新 Laravel 项目的用户注册?