C++11新特性(2)- 列表初始化
扫描二维码
随时随地手机看文章
以前什么样
C或者C++在初始化数组时,可以使用下面的花括号加初始值的形式:
int int_array[] = {1, 2, 3, 4, 5};
在C++中,如果有下面这样一个类:
class Tester
{
public:
Tester(int value)
:m_value(value * 2)
{ }
void print(){
cout << m_value << endl;
}
private:
int m_value;
};
那么它的初始化可以写成这样:
Tester tester_array[] = {6, 7, 8, 9, 10};
Tester的构造函数可以被正常地调用。
存在的问题
问题就是这种方法的运用范围很窄,许多场景都用不了。例如vector,可以像数组一样使用,可以自己管理数据长度,还提供各种操作数组的方法。声明的方法也很简单:
vector
但是有一个问题,当需要指定元素初始化vector时就不那么方便了。
初始化方法1:
int_vector.push_back(5);
int_vector.push_back(4);
int_vector.push_back(3);
int_vector.push_back(2);
int_vector.push_back(1);
初始化方法二:
int int_array[] = {1, 2, 3, 4, 5};
for(int i = 0; i < sizeof(int_array)/sizeof(int_array[0]); ++i)
{
int_vector.push_back(int_vector[i]);
}
无论那种方法,都给人一种如鲠在喉的感觉。
哪里有不方便,哪里就有改进
C++11中扩展了使用花括号初始化变量的应用范围,称这种初始化方式为列表初始化。
例如:
可以像下面这样初始化vector:
vector
可以像下面这样初始化list:
list
甚至可以像下面这样初始化map
map
另一种形式
下面和写法也合法,和上面的几种写法等价。
vector
list
map
有没有梦想成真的感觉?