C++11中initializer lists的使用
Before C++11,there was no easy way to do things like initialize a std::vector or std::map(or a custom container) to a set of values. You could do so for an old C-style array, but not easily for STL collections. Initializer Lists provide a solution to this problem. Thus, like with the auto keyword, they work to remove a lot of the verbosity that has traditionally attached with using the STL collection classes.
Uniform Initialization expands on the Initializer List syntax, to provide a syntax that allows for fully uniform type initialization that works on any object --removing the distinction between initialization of aggregate + non-aggregate classes, arrays, STL/custom collection classes, and PODs.
To support initializer list in a class (i.e. if creating your own collection), you simply define a constructor that takes a std::initializer_list as its parameter, which can then be used like a collection.
C++11引入了初始化列表来初始化变量和对象。自定义类型,如果想用初始化列表就要包含initializer_list头文件。
C++11将使用大括号的初始化(列表初始化)作为一种通用初始化方式,可用于所有类型。初始化列表不会进行隐式转换。
下面是从其他文章中copy的测试代码,详细内容介绍可以参考对应的reference:
#include "init_list.hpp" #include <iostream> #include <vector> #include <map> #include <string> #include <set> /////////////////////////////////////////// // reference: http://en.cppreference.com/w/cpp/language/list_initialization struct Foo { //std::vector<int> mem = { 1, 2, 3 }; // list-initialization of a non-static member //std::vector<int> mem2; //Foo() : mem2{ -1, -2, -3 } {} // list-initialization of a member in constructor }; std::pair<std::string, std::string> f(std::pair<std::string, std::string> p) { return{ p.second, p.first }; // list-initialization in return statement } int test_init_list1() { int n0{}; // value-initialization (to zero) int n1{ 1 }; // direct-list-initialization std::string s1{ 'a', 'b', 'c', 'd' }; // initializer-list constructor call std::string s2{ s1, 2, 2 }; // regular constructor call std::string s3{ 0x61, 'a' }; // initializer-list ctor is preferred to (int, char) int n2 = { 1 }; // copy-list-initialization double d = double{ 1.2 }; // list-initialization of a temporary, then copy-init std::map<int, std::string> m = { // nested list-initialization { 1, "a" }, { 2, { 'a', 'b', 'c' } }, { 3, s1 } }; std::cout << f({ "hello", "world" }).first << '\n'; // list-initialization in function call const int(&ar)[2] = { 1, 2 }; // binds a lvalue reference to a temporary array int&& r1 = { 1 }; // binds a rvalue reference to a temporary int // int& r2 = {2}; // error: cannot bind rvalue to a non-const lvalue ref // int bad{1.0}; // error: narrowing conversion unsigned char uc1{ 10 }; // okay // unsigned char uc2{-1}; // error: narrowing conversion Foo f; std::cout << n0 << ' ' << n1 << ' ' << n2 << '\n' << s1 << ' ' << s2 << ' ' << s3 << '\n'; for (auto p : m) std::cout << p.first << ' ' << p.second << '\n'; //for (auto n : f.mem) // std::cout << n << ' '; //for (auto n : f.mem2) // std::cout << n << ' '; return 0; } //////////////////////////////////////////// // reference: https://mbevin.wordpress.com/2012/11/16/uniform-initialization/ int test_init_list2() { int arr[] { 1, 2, 3, 4, 5 }; std::vector<int> v{ 1, 2, 3, 4, 5 }; std::set<int> s{ 1, 2, 3, 4, 5 }; std::map<int, std::string> m{ { 0, "zero" }, { 1, "one" }, { 2, "two" } }; return 0; } /////////////////////////////////////////////////////// // reference: https://mbevin.wordpress.com/2012/11/16/uniform-initialization/ // 'aggregate' class - no user-declared constructor, no private/protected members, no base, no virtual function struct ClassA { int x; double y; }; // non-aggregate class class ClassB { private: int x; double y; public: ClassB(int _x, double _y) :x(_x), y(_y) {} }; std::pair<double, double> multiplyVectors( std::pair<double, double> v1, std::pair<double, double> v2) { return{ v1.first*v2.first, v1.second*v2.second }; } int test_init_list3() { int i{ 3 }; int j{}; // empty braces initialize the object to it's default (0) std::string s{ "hello" }; ClassA objA1{}; ClassA objA2{ 1, 2.0 }; ClassB objB1{ 1, 2.0 }; ClassA arrOfAs[] = { { 1, 1.0 }, { 2, 2.0 }, { 3, 3.0 } }; // ouch, the theory is that this should work in C++11, however this doesn't compile, at least with clang, comments? ClassB arrOfBs[] = { { 1, 1.0 }, { 2, 2.0 }, { 3, 3.0 } }; // however, this does work std::vector<ClassB> vectorOfBs = { { 1, 1.0 }, { 2, 2.0 }, { 3, 3.0 } }; auto result = multiplyVectors({ 1.0, 2.0 }, { 3.0, 4.0 }); return 0; }
GitHub:https://github.com/fengbingchun/Messy_Test
C++11中initializer lists的使用的更多相关文章
- C++11 中值得关注的几大变化(网摘)
C++11 中值得关注的几大变化(详解) 原文出处:[陈皓 coolshell] 源文章来自前C++标准委员会的 Danny Kalev 的 The Biggest Changes in C++11 ...
- C++11 中值得关注的几大变化(详解)
源文章来自前C++标准委员会的 Danny Kalev 的 The Biggest Changes in C++11 (and Why You Should Care),赖勇浩做了一个中文翻译在这里. ...
- C++ 11中几个我比较喜欢的语法(二)
之前在文章C++ 11中几个我比较喜欢的语法中介绍了几个我比较喜欢的C++语法,其中有些语法由于VC 11还不支持,无法跨平台,所以没有介绍.前几天VS 2013 Preview发布后,对C++ 11 ...
- 从linux0.11中起动部分代码看汇编调用c语言函数
上一篇分析了c语言的函数调用栈情况,知道了c语言的函数调用机制后,我们来看一下,linux0.11中起动部分的代码是如何从汇编跳入c语言函数的.在LINUX 0.11中的head.s文件中会看到如下一 ...
- C++ 11 中的右值引用
C++ 11 中的右值引用 右值引用的功能 首先,我并不介绍什么是右值引用,而是以一个例子里来介绍一下右值引用的功能: #include <iostream> #include &l ...
- IOS中的Block与C++11中的lambda
ios中的block 可以说是一种函数指针,但更确切的讲,其实际上其应该算是object-c对C++11中lambda的支持或者说是一个语言上的变体,其实际内容是一样的,C++的lambda我已经有简 ...
- 在Windows 8.1及IE 11中如何使用HttpWatch
提示:HttpWatch现已更新至v9.1.8,HttpWatch v9.1及以上的版本现都已支持Windows 7,8,8.1和IE 11. 如果你的HttpWatch专业版授权秘钥允许进入vers ...
- C++11中对类(class)新增的特性
C++11中对类(class)新增的特性 default/delete 控制默认函数 在我们没有显式定义类的复制构造函数和赋值操作符的情况下,编译器会为我们生成默认的这两个函数: 默认的赋值函数以内存 ...
- callable object与新增的function相关 C++11中万能的可调用类型声明std::function<...>
在c++11中,一个callable object(可调用对象)可以是函数指针.lambda表达式.重载()的某类对象.bind包裹的某对象等等,有时需要统一管理一些这几类对象,新增的function ...
随机推荐
- Android(java)学习笔记17:网络编程的概述
1. 计算机网络 计算机网络是指将地理位置不同的具有独立功能的多台计算机及其外部设备,通过通信线路连接起来,在网络操作系统,网络管理软件及网络通信协议的管理和协调下,实现资源共享和信息传递的计算机系统 ...
- html常见元素和理解
html常见元素分为两类,一类是header区的元素,一类是body区的元素 header区元素: meta title style link scipt base 里面包括像meta,title,s ...
- POJ 1088 滑雪 【记忆化搜索经典】
题目链接:http://poj.org/problem?id=1088 滑雪 Time Limit: 1000MS Memory Limit: 65536K Total Submissions: ...
- IntelliJ Idea 常用快捷键列表和快速输入
IntelliJ Idea 常用快捷键列表和快速输入 快速输入查看 最常用快捷键 Alt+Enter 万能快捷键,用于引入错误包 Ctrl+ Mouse left 快速调转定义 快捷键 Ctrl+Sh ...
- 【洛谷T37388】P哥破解密码
原题图: 看到这个题,首先想到的当然是暴力打表找规律了 表: 1 2 2 4 3 7 4 13 5 24 6 44 7 81 8 149 9 274 10 504 11 927 12 1705 13 ...
- TDD: 解除依赖
1 A类依赖B 类,可以把B类提取成IB接口,解除AB 之间的依赖关系. 通过创建实现了IB接口的BStub 装代码,可以模拟B类进行测试. 这是针对接口编程的典型.适合构造代价大,变化多的情况.应 ...
- 运行Python
安装好python环境,在Windows系统下运行cmd命令行,是windows提供的命令行模式. 在命令行下,可以执行python进入Python交互式环境,也可以执行python hello.py ...
- watch、computed、methods的区别
1. `computed`属性的结果会被缓存,除非依赖的响应式属性变化才会重新计算.主要当作属性来使用,要return出去一个值:2. `methods`方法表示一个具体的操作,主要书写业务逻辑:3. ...
- 菜鸟笔记 -- Chapter 6.1 面向对象概述
6.1 面向对象概述 在程序开发的初期人们使用结构化开发语言,但是随着时间的流逝,软件的规模越来越庞大,结构化语言的弊端逐渐暴露出来,开发周期被无限制拖延,产品质量也不尽如人意,人们终于发现结构化语言 ...
- oracle-sql脚本导出EXCEL数据
在数据库中,经常有业务人员提出需求导出数据库中的业务数据,而且是每天.每周或每月定时导出.为了方便,可将sql查询的脚本 通过下面脚本来导出EXCEL数据. 1.将查询sql脚本(AAA.sql)放到 ...