Why can#39;t I initialize a reference in an initializer list with uniform initialization?(为什么我不能使用统一初始化初始化初始化列表中的引用?)
问题描述
也就是说,为什么会这样:
That is, why does this:
struct S {};
struct T
{
T(S& s) : s{s} {}
S& s;
};
int main()
{
S s;
T t{s};
}
给我一个 GCC 4.7 的编译器错误:
give me a compiler error with GCC 4.7:
test.cpp: In constructor 'T::T(S&)':
test.cpp:5:18: error: invalid initialization of non-const reference of type 'S&' from an rvalue of type '<brace-enclosed initializer list>'
?
要修复错误,我必须将 s{s}
更改为 s(s)
.这不会破坏,呃,统一初始化的统一性吗?
To fix the error, I have to change the s{s}
to s(s)
. Doesn't this break the, erm, uniformity of uniform initialization?
编辑:我尝试使用 clang,并且 clang 接受了它,所以也许这是一个 GCC 错误?
EDIT: I tried with clang, and clang accepts it, so perhaps it's a GCC bug?
推荐答案
是的,它是一个 错误.这是新事物,并在 2012 年 2 月的工作文件中投票(link).
Yes, its a bug. This is something new and was voted in the working paper in February 2012 (link).
Nicol Bolas 说得很好,因为 gcc 实际上是符合 FDIS 批准的 C++11 标准的编译器,因为在此之后对工作文件进行了更改.
Nicol Bolas makes a good point in that gcc is actually the conforming compiler according to the FDIS approved C++11 standard because the changes to the working paper were made after that.
这篇关于为什么我不能使用统一初始化初始化初始化列表中的引用?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:为什么我不能使用统一初始化初始化初始化列表中的引用?


- 一起使用 MPI 和 OpenCV 时出现分段错误 2022-01-01
- 静态初始化顺序失败 2022-01-01
- C++ 协变模板 2021-01-01
- 与 int by int 相比,为什么执行 float by float 矩阵乘法更快? 2021-01-01
- 从python回调到c++的选项 2022-11-16
- 近似搜索的工作原理 2021-01-01
- 使用/clr 时出现 LNK2022 错误 2022-01-01
- STL 中有 dereference_iterator 吗? 2022-01-01
- 如何对自定义类的向量使用std::find()? 2022-11-07
- Stroustrup 的 Simple_window.h 2022-01-01