如果静态成员未初始化并且成员类型是类本身,该怎么办?
What if a static member is not initialized and the member type is class itself?
类的定义是这样的:
class Singleton {
public:
static Singleton instance_;
private:
Singleton() {
cout << "constructorn";
}
};
在函数中:
Singleton instance = Singleton::instance_;
代码可以编译,并且不会引发任何错误。如果我这样使用它:
Singleton &instance = Singleton::instance_;
引发链接错误。我想知道为什么第一个案例可以正确编译?而且我知道没有调用构造函数。在第一种情况下,实例的对象状态是什么?第一种情况有意义吗?
这两种形式都是代码中的错误,但在这两种情况下,编译器/链接器都可以静默忽略错误,不需要检测它。
Singleton instance = Singleton::instance_;
使用隐式生成的复制构造函数。它从Singleton::instance_
复制所有 0 个非静态数据成员,因此可能会被完全优化。因此,您在没有定义的情况下使用Singleton::instance_
这一事实可能会被忽视。
Singleton &instance = Singleton::instance_;
绑定到Singleton::instance_
,并要求知道其地址。因此,如果未定义Singleton::instance_
则更有可能导致错误。
提供Singleton::instance_
定义的方法是
Singleton Singleton::instance_;
在文件范围内。
静态成员仅在定义类时声明。它们必须在类定义之外定义。在您的情况下,您应该写:
类单例 {
public:
static Singleton instance_; // declare the static member
private:
Singleton() {
cout << "constructorn";
}
};
Singleton Singleton::instance_; // defines the static member
这主要用于需要非平凡构造的情况,但是如果您忘记定义静态成员,则它不存在,并且在运行时会出现链接错误或未定义的行为。
相关文章:
- ArduinoJson 6.15.2:JsonObject没有命名类型
- 防止主数据类型C++的隐式转换
- 大量序列中核苷酸类型的快速计数
- 如何从C++中的依赖类型中获得它所依赖的类型
- 有关插入适配器的错误。[错误]请求从 'back_insert_iterator<vector<>>' 类型转换为非标量类型
- 是否可以初始化不可复制类型的成员变量(或基类)
- 如何获取std::result_of函数的返回类型
- 从父命名空间重载类型
- 如果C++类在类方法中具有动态分配,但没有构造函数/析构函数或任何非静态成员,那么它仍然是POD类型吗
- 我想将一个对T类型的非常量左值引用绑定到一个T类型的临时值
- Openssl 1.1.1d无效使用不完整的类型"struct dsa_st"
- 访问者访问变体并返回不同类型时出错
- 在VS2010-VS2015下编译时,如何使用decltype作为较大类型表达式的LHS
- 处理小于cpu数据总线的数据类型.(c++转换为机器代码)
- C++ 雷神库 - 使用资源加载器类时出现问题(不命名类型)
- 如果我忽略返回类型shared_ptr函数的返回值怎么办
- 如果静态成员未初始化并且成员类型是类本身,该怎么办?
- 如果我们不想要模板/泛型中的任何数据类型怎么办
- c++ Koenig(参数依赖)查找:如果不同名称空间中的两个名称空间函数具有相同的参数类型该怎么办?
- 从不兼容的指针类型初始化-现在怎么办