组合静态构件及方法

Combined static member and method

本文关键字:方法 构件 静态 组合      更新时间:2023-10-16

考虑一个具有静态成员和静态方法来设置成员值的类(以下基于@JamesKanze的示例(:

class A_EXPORT InA
{
    public:
     static FILE* ourDest;
     static void setDest( FILE& dest );
};

Dr. Dobbs 中的一篇文章(关于日志记录(建议将静态成员和静态方法组合如下:

// in header file
class A_EXPORT InA
{
    public:
     static FILE*& theDest();  // a static member that is a static method too!
};
// in cpp file
FILE*& InA::theDest()
{
    static FILE* pStream = stderr;
    return pStream;
}
// in user's file
InA::theDest()  =  fopen("log.txt","a"); //std::ofstream( "log.txt" );

问:组合静态成员和静态方法的优缺点是什么?

这种模式通常被称为Meyer's singleton,是Singleton设计模式的实现。

主要优点是它能够处理静态初始化顺序惨败,这基本上是无法预测静态对象在翻译单元中初始化的顺序。

第二个版本的主要优点是避免了静态初始化顺序的惨败

如果ourDest有一个构造函数,那么另一个静态对象的构造函数可能会在ourDest的构造函数运行之前尝试使用ourDest,从而导致未定义的行为。

但是,如果静态对象是在函数内部定义的,那么它是在第一次命中该定义时构造的,因此在构造之前不可能访问它。

在你的例子中(就像Dr. Dobbs的情况(,你的theDest()函数以类似的方式"构造"pStream;这样做可以确保没有人使用pStream并发现它是空的。在第一种情况下,如果在调用 outDest 之前读取setDest,则它可能为 null。