为什么int&a=10;在古代C++编译器中有效吗?
Why int& a=10; is valid in ancient C++ compilers?
我只是想知道为什么像Turbo c ++ 3.0(蓝屏IDE)和Borland Turbo C++ 4.5等古老的编译器在以下程序中没有报告任何错误。
#include <iostream.h>
int main()
{
int& a=10;
cout<<a;
return 0;
}
上面的程序不会被现代C++编译器接受,但是为什么古代编译器允许这样做呢?它们只是在上面的程序中显示单个警告。
它曾经是有效的C++将引用绑定到临时的,因此您可以传递例如 double
期望int&
的函数,如C++的设计与演变§3.7中所解释的那样:
但是,我犯了一个严重的错误,允许非
const
引用由非左值初始化。[...]
允许引用由非 lvalues 初始化的原因是允许按值调用和按引用调用之间的区别是由被调用函数指定的细节,并且调用方不感兴趣。对于const
参考文献,这是可能的,对于非const
参考文献则不是。对于 2.0 版,更改了C++的定义以反映这一点。
在 C++ 2.0(和 ISO C++)中,临时只能绑定到const
引用。
相关文章:
- C/C++编译器通常会删除重复的库吗
- 模板-模板参数推导:三个不同的编译器三种不同的行为
- Win32编译器选项和内存分配
- MSVC多行宏编译器错误
- 静态数据成员的问题-修复链接错误会导致编译器错误
- C++,我收到一个无法理解的编译器错误
- 在线编译器中的分段C++没有打印消息
- 如何解决gcc编译器优化导致的centos双编译器设置中的分段错误
- C/C++预处理器是否可以检测一些编译器选项
- 是否有C++编译器选项允许激进地删除所有函数调用,并将参数传递给具有空体的函数
- C++错误C2600:无法定义编译器生成的特殊成员函数(必须首先在类中声明)
- 我需要知道编译器如何在cpp中使用析构函数
- 编译器如何区分std::vector的构造函数
- CLANG 编译器 说:变量"PTR"可能未初始化
- 告诉c++编译器该参数没有别名
- 使用仅使用一次的变量调用的复制构造函数.这可能是通过调用move构造函数进行编译器优化的情况吗
- 为什么所有C++编译器都会崩溃或挂起此代码
- 编译器如何在使用SFINAE的函数和标准函数之间确定两者是否可行
- 我收到同义重复编译器错误。我应该如何修复"类型"X"的参数与类型"X"的参数不兼容?
- 为什么C++编译器没有检测到正确声明的类?