C++11新标准允许使用花括号括来初始化变量或者进行赋值,默认为列表初始化/赋值的方式。
int i { 2 };
int j = { 3 };
vector<int> vi { i, j };
vector<int> vj = { 2, 3, 5};
1)花括号内的内容可以为0个。如果是一个内置类型对象,那么初始值列表最多只能包含一个值,而且该值即使转换其所占空间也不应该大于目标类型的空间
int i {}; // 初始值默认为0
int j { 2, 3}; // 编译错误,内置类型初始值个数不能给你超过1个
int k { 2.13}; // 编译错误,会有精度丢失
int m = 2.13; // m被初始化为2
vector<int> vi = {}; // vi中没有元素
2)如果使用花括号,会尽可能将花括号内的值当成元素初始值列表来处理,只有当无法执行列表初始化时才会考虑其它初始化方式
vector<string> v1{"hi"}; // 列表初始化,vi只有一个元素
vector<string> v2("hi"); // 编译错误,没有匹配的构造方法
vector<string> v3{10}; // 类型不匹配,转换为构造方法参数,v3有10个默认初始化的元素
vector<string> v4{10, "hi"}; // 类型不匹配,转化为构造方法参数,v4有10个元素,值都为"hi"
3)花括号实际上是通过initializer_list的方式来实现
vector (initializer_list<value_type> il,
const allocator_type& alloc = allocator_type()); //vector使用initializer_list进行初始化
C++11中提供了initializer_list类(初始值列表,定义在initializer_list头文件中),用于处理参数类型相同但是数量可变的情况
initializer_list<T> lst; // 默认初始化,元素列表为空
initializer_list<T> lst{a, b,c...}; // lst的元素为对应初始值的副本,列表中元素均为const,不能修改
lst2(lst) 拷贝操作,不会拷贝列表中的元素
lst2 = lst 赋值操作,不会拷贝列表中的元素
lst.size() 返回列表的大小
lst.begin() 返回指向lst中首元素的指针
lst.end() 返回指向lst中尾元素下一个位置的指针
初始值列表并没有提供可以增删元素的操作,所以只能可以通过花括号的方式构造initializer_list对象,然后作为参数传入,使用时通过迭代器进行遍历。