[英]Static initializer of shared library inside dynamic library
所以我有一个静态库(MacOS,.a库)。 它是用C ++编写的,并且在它的代码中有静态初始化器:
//myclass.hpp
class MyClass {
...
static MyClass *defaultValue_;
static MyClass *newInitialDefaultValue();
...
}
...
//myclass.cpp
MyClass *MyClass::defaultValue_ = newInitialDefaultValue();
...
我正在将.dylib库链接到这个.a lib。 不幸的是,当加载我的.dylib文件时,不会调用MyClass::newInitialDefaultValue()
。 可能是什么原因以及如何处理这个问题?
我已经尝试了-all_load
和-force_load
链接器标志而没有运气。
all_load和force_load链接器标志仅确保代码链接到二进制文件。 我认为这些旗帜不会对你有所帮助。
我认为你可以依赖的唯一保证是,在调用同一个cpp文件中的任何其他代码之前,将调用myclass.cpp中的初始化程序。 您需要通过函数公开对默认值的访问。 这与Singleton模式类似。 例如:
//myclass.hpp
class MyClass {
...
static MyClass *getDefaultValue();
...
}
...
//myclass.cpp
static MyClass* defaultValue_; // Note that this is not a member variable
MyClass* MyClass::getDefaultValue() {
if (defaultValue_ == nullptr) {
defaultValue_ = newInitialDefaultValue();
}
return defaultValue_;
}
...
注意:我没有尝试使此线程安全或处理错误。
现在,加载库时,defaultValue_仍然不会自动初始化。 但由于唯一的访问调用者是通过getDefaultValue(),因此可以保证在访问它时进行初始化。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.