c++中引用的澄清
Clarification of References in C++
所以我正在尝试学习c++,我遇到了一些让我有点困惑的事情。我有代码,
int x = 0;
int &y = x;
cout << &x<< " " << x << " " << &y << " " <<y<< endl;
编译得很好,结果是:
0 003AFA08 0 003AFA08
我很难理解为什么将int型x转换为引用型&y不会导致错误。一开始我以为这是某种转换,然而,
int &y = &x;
导致错误。
谁能解释一下为什么会这样?
int&
不是地址。它是一个引用。
int& y = x;
声明y
为x
的引用。这实际上意味着y
成为x
的另一个名称。当你使用y
时,就好像你说的是x
。
指针(不是引用)用于存储地址。int& y = &x;
是无效的,因为&x
是x
的地址(它是int*
)。y
是对int
的引用,而不是对int*
的引用
这不是转换。当你有一个变量类型T &
,其中T
是一些随机类型,你基本上是说"我正在声明一个名字,这是另一个名字的别名,或者可能是一个匿名值。"它更像一个typedef
而不是一个指针。
引用碰巧经常被实现为地址,但这不是一个思考它们是什么的好模型。
在你困惑的例子中:
int * const &y = &x;
就可以了。然后,y
成为获取x
地址的临时结果的别名。注意,这是对指针的引用。它必须是对常量指针的引用,因为它是对临时值的引用。
相关文章:
- 将对象数组的引用传递给函数
- 什么时候在C++中返回常量引用是个好主意
- 我想将一个对T类型的非常量左值引用绑定到一个T类型的临时值
- 何时在引用或唯一指针上使用移动语义
- 如何在c++中使用引用实现类似python的行为
- 编译C++时未定义的引用
- Ctypes wstring通过引用传递
- c++r值引用应用于函数指针
- 理解c++中的引用
- C++取消引用指针.为什么会发生变化
- 如何修复此错误:未定义对"距离(浮点数,浮点数,浮点数,浮点数,浮点数)"的引用
- 我的项目不会像"undefined reference to `grpc::g_core_codegen_interface'"那样使用未定义的引用错误进行编译
- C++Boost Asio Pool线程,带有lambda函数和传递引用变量
- 强制转换为引用类型
- 引用一个已擦除类型(void*)的指针
- 向量元素的引用地址与它所指向的向量元素的地址不同.为什么
- 具有默认值的引用获取函数
- 如何使用基类指针引用派生类成员
- 使用取消引用的指针的多态性会产生意外的结果.为什么?
- 如何引用基类的派生类?