在C++11中初始化类成员变量
Initialize class member variables in C++ 11
考虑以下类定义:
class C {
public:
int i = 9;
const int j = 2;
};
在编译时(使用g++,例如g++ -o test test.cpp
),如果不使用该标志来启用C++11,编译器会抱怨成员变量初始化。但是,使用-std=c++11
可以正常工作。
为什么这个规则在C++11中被更改了?以这种方式初始化成员变量是否被认为是不好的做法?
在非静态数据成员声明时初始化它们不仅仅是"坏做法";在C++11之前根本不可能。
等效的C++03代码是:
class C
{
public:
C() : i(9), j(2)
{
}
int i;
const int j;
};
以防万一:构造函数中这种奇怪的冒号成员语法是什么?
相关文章:
- 将成员变量添加到共享库中的类中,不会破坏二进制兼容性吗
- 具有奇怪重复模板模式的派生类中的成员变量已损坏
- 内置函数可查看CPP中的成员变量
- 是否可以初始化不可复制类型的成员变量(或基类)
- 将包含C样式数组的对象初始化为成员变量(C++)
- 为什么我不能在一个类的不同行中声明和定义成员变量?
- 在循环中按顺序遍历成员变量
- c++类声明时,相同的例程,不同的成员变量类型
- 如何从另一个文件继承私有成员变量和公共函数
- 在C++类中,是否必须初始化作为数组的成员变量
- 如何从子成员函数修改父公共成员变量
- 我可以在 C++ 中将数据成员/变量从其定义之外添加到结构中吗?
- 从私有成员变量的成员方法返回unique_ptr
- 在派生类中使用基类的私有成员变量的最佳方法
- 静态 constexpr 类成员变量对多线程读取是否安全?
- C++:是否可以使用非静态成员变量模板?
- 打印所有继承的类成员变量和方法
- 如何在复杂继承中访问静态成员变量
- 为什么我不能在返回 const 的布尔函数中为类成员变量赋值?C++
- 成员变量与函数概念检查