4

我有带有静态成员的静态库。该库静态链接到主应用程序及其插件之一。看起来像在 main(应用程序)和 dll(插件)中初始化的静态变量。

问题:动态库加载时如何避免静态变量重新初始化。或者我可能错过了一些简单的东西?

更多信息:

这是一个简单的静态库,包含静态成员,它是 getter 和 setter:

orbhelper.h

class ORBHelper {
    static std::string sss_;
public:
    static std::string getStr();
    static void setSTR(std::string str);
};

orbhelper.cpp

std::string ORBHelper::sss_ = "init";

static std::string ORBHelper::getStr()
{
    std::cerr << "get " << sss_.c_str() << std::endl;
    return sss_;
}
static void ORBHelper::setSTR(std::string str)
{
    sss_ = str;
    std::cerr << "set " << sss_.c_str() << std::endl;
}

这个库在 main.cpp 和另一个动态库中使用,它在 main 中加载。在 main.cpp 中,我设置了静态字符串,并在其中一个动态库函数中获取它。

在 main 中设置静态变量:

主文件

...
ORBHelper::setStr("main");
std::cerr << ORBHelper::getStr().c_str() << std::endl; //prints 'main'
//then loading library
...

然后在dll中获取变量值:

hwplugin.cpp

...
std::cerr << ORBHelper::getStr().c_str() << std::endl; //prints 'init' instead of 'main'
...

看起来静态变量已被初始化两次。第一个 - 在 main.cpp 之前,第二个 - 加载动态库时。具有静态类的静态库链接到主应用程序和动态库。

PS 在我的问题中有太多“静态”字眼,我知道 =)

4

1 回答 1

0

是的,您有两个辅助类实例。

DLL 应该链接到链接静态类的可执行文件,并使用它来解析帮助程序类。不要将 DLL 与静态库链接,而是将其链接到可执行文件本身。

于 2012-05-12T07:33:29.857 回答