c++11初始化列表(initializer_list)

目录

写在前面

详述

initializer_list部分源码

方法

使用

参考文献


 

写在前面

c++11标准中,initializer_list对于标准库的编写影响非常大,说一个简单的例子,在c++11之前,max函数的源程序是这样的:

template <class T> const T& max (const T& a, const T& b);
template <class T, class Compare>
  const T& max (const T& a, const T& b, Compare comp);  //支持自己编写的比较函数

也就是max函数只能比较两者之间的大小,但是有了initializer_list后,c++11标准库中添加另外一种实现方式:

template <class T> T max (initializer_list<T> il);
template <class T, class Compare>
  T max (initializer_list<T> il, Compare comp);

这就说明,c++11之后,max函数可以传递更多的参数,栗子:

cout << max({ 54,16,48,5 }) << endl;   //输出54

可以说:initializer_list是某种类型的数组,但是内部数据都是const T类型,可以整体作为参数传递,由{}进行初始化

详述

c++11中统一了初始化列表(Uniform Initiaization),即均可以使用{}来对对象进行初始化。例如:

int value[]{1,2,3};
vector<int> v{2,3,4,5,6,7};
vector<string> cities{"Beijing&
initializer_listC++11标准引入的一种数据结构,用于表示一个初始化列表。它可以用于函数参数、构造函数、赋值等场合。 初始化列表是由一系列用逗号隔开的值组成的,可以用花括号括起来。例如,{1, 2, 3}就是一个初始化列表,其中包含了三个整数1、2、3。 initializer_list的定义如下: ```cpp template<class T> class initializer_list { public: typedef const T* iterator; typedef const T& reference; typedef size_t size_type; initializer_list() noexcept; initializer_list(const T* p, size_t n) noexcept; size_t size() const noexcept; const T* begin() const noexcept; const T* end() const noexcept; }; ``` 使用initializer_list需要包含头文件<initializer_list>。 可以通过以下方式初始化initializer_list: ```cpp std::initializer_list<int> il = {1, 2, 3}; ``` 在函数参数中使用initializer_list可以方便地传递一组值: ```cpp void foo(std::initializer_list<int> il) { for (auto it = il.begin(); it != il.end(); ++it) { std::cout << *it << std::endl; } } foo({1, 2, 3}); ``` 在类的构造函数中使用initializer_list可以方便地对成员变量初始化: ```cpp class MyClass { public: MyClass(std::initializer_list<int> il) { for (auto it = il.begin(); it != il.end(); ++it) { vec.push_back(*it); } } private: std::vector<int> vec; }; MyClass mc = {1, 2, 3}; ``` 总之,initializer_list是一个十分方便的工具,可以用于各种场合,使代码更加简洁、清晰。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值