之前写了一个博客《 [浅析C++中的初始化列表(区别赋值和初始化)](http://blog.csdn.net/wangshubo1989/article/details/48937325 "成员变量初始化")》,讲述了类的构造函数使用初始化列表来初始化成员变量。
现在,撇开过往不谈,就谈一谈普通的变量赋值。即是我们要提到的initializer_list。
这同样是一个C++11的特性。
过往,我们这样给vector赋值:
~~~
std::vector v;
v.push_back(1);
v.push_back(2);
v.push_back(3);
v.push_back(4);
~~~
需要感谢的是,C++11让你更方便。
~~~
std::vector v = { 1, 2, 3, 4 };
~~~
这就是所谓的initializer list。
更进一步,有一个关键字叫initializer list
C++11允许构造函数和其他函数把初始化列表当做参数。
~~~
#include <iostream>
#include <vector>
class MyNumber
{
public:
MyNumber(const std::initializer_list<int> &v) {
for (auto itm : v) {
mVec.push_back(itm);
}
}
void print() {
for (auto itm : mVec) {
std::cout << itm << " ";
}
}
private:
std::vector<int> mVec;
};
int main()
{
MyNumber m = { 1, 2, 3, 4 };
m.print(); // 1 2 3 4
return 0;
}
~~~
最后写一个类,可以对比一下,加深理解
~~~
class CompareClass
{
CompareClass (int,int);
CompareClass (initializer_list<int>);
};
int main()
{
myclass foo {10,20}; // calls initializer_list ctor
myclass bar (10,20); // calls first constructor
}
~~~
这下子明白 {} 和 () 的区别了吧!!!
- 前言
- 吐血整理C++11新特性
- C++11新特性之std::function
- c++11特性之正则表达式
- c++11特性之Lambda表达式
- c++11特性之override和final关键字
- c++11特性之std::thread--初识
- c++11特性之std::thread--初识二
- c++11特性之initializer_list
- c++11特性之std::thread--进阶
- c++11特性之std::thread--进阶二
- C++11新特性之 CALLBACKS
- C++11新特性之 std::array container
- C++11新特性之 nullptr
- C++11新特性之 rvalue Reference(右值引用)
- C++11新特性之 Move semantics(移动语义)
- C++11新特性之 default and delete specifiers
- C++11新特性之 Static assertions 和constructor delegation
- 开始使用C++11的几个理由
- C++11新特性之 std::future and std::async