嵌套模板函数中的 C 静态成员初始化
静态成员初始化可以通过嵌套辅助结构来实现,尤其是在非模板化类中。但是,当封闭类由模板参数化时,这种方法可能会遇到问题。具体来说,如果在主代码中未访问辅助对象,则嵌套初始化类可能不会实例化。
考虑以下简化示例,该示例说明了向量的初始化:
<code class="cpp">struct A { struct InitHelper { InitHelper() { A::mA = "Hello, I'm A."; } }; static std::string mA; static InitHelper mInit; static const std::string& getA(){ return mA; } }; std::string A::mA; A::InitHelper A::mInit; template<class T> struct B { struct InitHelper { InitHelper() { B<T>::mB = "Hello, I'm B."; } }; static std::string mB; static InitHelper mInit; static const std::string& getB() { return mB; } static InitHelper& getHelper(){ return mInit; } }; template<class T> std::string B<T>::mB; template<class T> typename B<T>::InitHelper B<T>::mInit;</code>
使用 g 4.4.1 编译时,会出现以下几个观察结果:
此行为源于编译器对 ISO/IEC C 2003 标准 (14.7.1) 的解释。该标准规定:
“除非类模板或成员模板的成员已被显式实例化或显式特化,否则当在类模板中引用特化时,会隐式实例化该成员的特化。需要成员定义存在的上下文;特别是,除非静态数据成员本身以需要静态数据成员定义的方式使用,否则不会发生静态数据成员的初始化(以及任何相关的副作用) ”
这解释了为什么在给定的示例中,静态成员在通过 getB() 或 getHelper() 方法访问之前不会被初始化。在主函数中显式实例化类模板或成员模板将强制它们在此时初始化。然而,对于直接访问不可行的场景,该标准没有指定一种优雅的解决方法来初始化嵌套模板函数中的静态成员。
以上是如何在 C 中的嵌套模板函数中初始化静态成员?的详细内容。更多信息请关注PHP中文网其他相关文章!