在类定义中初始化同一类的对象时出错- c++
error initializing an object of the same class within class definition - C++
我正在尝试实现以下类。然而,当我尝试在其定义内实例化类的对象并传递"0"作为初始化对象的值时,我得到一个错误:
"需要一个类型说明符"。
谁能解释我怎么才能消除这个错误?
class MessageType
{
public:
static const MessageType msgEvent(0);
private:
MessageType();
virtual ~MessageType();
MessageType(int);
};
您需要在cpp文件的类定义之外初始化(定义)它。
MessageType const MessageType::msgEvent;
然而,你方这样做的意图并不十分明确。如果您正在尝试实现单例模式,可能这个示例实现会有所帮助,我把它留给您来决定,您是否真的需要单例模式,尽管它有缺点:
//MessageType.h
#include <boost/noncopyable.hpp>
class MessageType: private boost::noncopyable
{
public:
static MessageType* instance();
private:
MessageType();
~MessageType();
static bool g_initialised;
// static initialisation
static MessageType g_instance;
// dynamic initialisation
};
// MessageType.cpp
#include "MessageType.hpp"
#include <ostream>
#include <iostream>
#include <cstring>
bool MessageType::g_initialised;
// static initialisation
MessageType MessageType::g_instance;
// dynamic initialisation
MessageType::MessageType()
{
g_initialised = true;
}
MessageType::~MessageType()
{
g_initialised = false;
}
MessageType* MessageType::instance()
{
return g_initialised ? &g_instance : 0;
}
只能在定义中初始化int类型的静态成员变量。
class MessageType
{
public:
static int sCount = 0; // That is fine.
static std::string sLogName; // That is fine.
static std::string sLogName("log.txt"); // Fail!
};
没有办法绕过这个规则。如果要初始化静态成员变量,则必须在cpp:
中进行。std::string MessageType::sLogName("log.txt"); // fine, in the cpp.
同样的规则直接适用于你的MessageType实例,与类是它自己的类型无关。
相关文章:
- 什么时候调用组成单元对象的析构函数
- 对RValue对象调用的LValue ref限定成员函数
- CMake-按正确顺序将项目与C运行时对象文件链接
- 空基优化子对象的地址
- 将对象数组的引用传递给函数
- 你能重载对象变量名本身返回的内容吗
- C++使用整数的压缩数组初始化对象
- 找不到成员对象:没有名为get_event()的成员,也处理多态性和向量
- 将对象移动到std::shared_ptr
- 代理对象的常量正确性
- 提升 ASIO 无法识别计时器对象
- 将Ref对象作为类成员
- 将包含C样式数组的对象初始化为成员变量(C++)
- 如何返回一个类的两个对象相加的结果
- 使用std::函数映射对象方法
- 是否需要删除包含对象的"pair"?
- 如何在自删除后将对象设置为nullptr
- 迭代时从向量和内存中删除对象
- 构造对象的歧义
- 使用"std::unordereded_map"映射到"std::list"对象