gpt4 book ai didi

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

转载 作者:太空宇宙 更新时间:2023-11-04 13:57:11 25 4
gpt4 key购买 nike

我的情况是,我想创建一个包含工厂的库,我们称它为 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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com