c++ 11/ c++ 14中的auto和大括号初始化
auto and brace initialization in C++11/C++14
当我用clang和gcc编译下面的代码时,T
的推导是不同的。
#include<initializer_list> //for clang
//to see how T is deduced(form compiler error).
template<typename T>
void foo(T);
int main() {
auto var1{2};
foo(var1);
}
这是我得到的。
clang 3.6(c++11/c++14)
gcc 4.9(c++11/c++14)
T = std::initializer_list<int>
gcc 5.1(c++11/c++14)
T = int
我认为T
应该是std::initializer_list<int>
。
为什么T = int
在gcc 5.1?
这是对c++ 17规范N3922的提议变更(我不确定它是否已被接受)。
基本上这是Scott Meyers的演讲,幻灯片20涵盖了新规则。
auto var1 {2} ;
这里,var1
将被演绎为int
。
看起来一些编译器已经实现了这个改变。我相信这种改变更"直观",但你的情况可能会有所不同。我认为在这个过渡阶段,更喜欢=
初始化,它可能更可移植。
这里的答案更详细地介绍了提出的建议和缺陷的历史。
相关文章:
- 是否可以初始化不可复制类型的成员变量(或基类)
- C++使用整数的压缩数组初始化对象
- C++初始化基类
- 多成员Constexpr结构初始化
- 复制列表初始化的隐式转换的等级是多少
- 内联映射初始化的动态atexit析构函数崩溃
- 如何在C++中初始化嵌套类中的2个memeber
- 如何声明特征矩阵,然后通过嵌套循环初始化它
- 没有用于初始化C++中的变量模板的匹配构造函数
- 在未初始化映射的情况下,将值插入到映射的映射中
- C++成员初始化
- 为什么在C++中首先初始化成员类
- 同时具有"聚合初始化"和"模板推导"
- 初始化具有非默认构造函数的std::数组项的更好方法
- 是否可以在编译时初始化数组,以便在运行时不会花费时间?
- 我可以使用条件运算符初始化C风格的字符串文字吗
- 在C和C++中初始化结构中的数组
- 标准是否使用多余的大括号(例如 T{{{10}}})定义列表初始化?
- 在函数内部的声明中初始化数组,并在外部使用它
- 继承:构造函数,初始化C++11中基类的类C数组成员