以下示例中给出的构造有什么不幸之处?
What is unfortunate about the construction given in the following example?
本文关键字:什么 更新时间:2023-10-16
"15.6.2 初始化基和成员"(N4713(具有以下示例,如第11项:
struct A {
A() = default; // OK
A(int v) : v(v) { } // OK
const int& v = 42; // OK
};
A a1; // error: ill-formed binding of temporary to reference
A a2(1); // OK, unfortunately
示例最后一行中的构造有什么不幸之处?
我搜索了整个参考资料,寻找其他允许的"不幸"行为,但我找不到。
如果在这种特殊情况下是不幸的,难道它不能被定为非法吗?
在这两种情况下,A::v
都是悬空引用(从 42 临时或构造函数的参数v
(。
在某些情况下,引用临时(即使具有延长的生存期(可能是合法的,并且可以正确使用。
很难检测到所有滥用案例以禁止它们。
相关文章:
- 为不同配置设置MSVC_RUNTIME_LIBRARY的正确方法是什么
- 警告处理为错误这里有什么问题
- 什么时候调用组成单元对象的析构函数
- #定义c-预处理器常量..我做错了什么
- 努力将整数转换为链表。不知道我在这里做错了什么
- C++我的数学有什么问题,为什么我的代码不能正确循环
- 什么时候在C++中返回常量引用是个好主意
- 当在同一名称空间中有两个具有相同签名的函数时,会发生什么
- C++避免重复声明的语法是什么
- c++库的公共头文件中应该包含什么
- 问题:什么是QAbstractItemView::NoEditTriggers的反面
- 有什么方法可以遍历结构吗
- 当类在C++中定义时,有什么方法可以"register"类吗?
- ifstream什么都没读
- 在C++中,将大的无符号浮点数四舍五入为整数的最佳方法是什么
- 实现无开销push_back的最佳方法是什么
- C++从另一个类访问公共静态向量的正确方法是什么
- "throw expression code" 1e7 >返回 d 是什么?投掷标准::overflow_error( "too big" ) : d;意味 着?
- 我应该使用什么来代替void作为变体中的替代类型之一
- 有没有什么方法可以使用一个函数中定义的常量变量,也可以由c++中同一程序中的其他函数使用