dereferencing a pointer when passing by reference(通过引用传递时取消引用指针)
问题描述
通过引用传递给函数时取消引用指针会发生什么?
what happens when you dereference a pointer when passing by reference to a function?
这是一个简单的例子
int& returnSame( int &example ) { return example; }
int main()
{
int inum = 3;
int *pinum = & inum;
std::cout << "inum: " << returnSame(*pinum) << std::endl;
return 0;
}
是否产生了临时对象?
推荐答案
取消引用指针不会创建副本;它创建一个 lvalue 指向指针的目标.这可以绑定到 lvalue 引用参数,因此函数接收对指针指向的对象的引用,并返回对相同对象的引用.这种行为是明确定义的,不涉及临时对象.
Dereferencing the pointer doesn't create a copy; it creates an lvalue that refers to the pointer's target. This can be bound to the lvalue reference argument, and so the function receives a reference to the object that the pointer points to, and returns a reference to the same. This behaviour is well-defined, and no temporary object is involved.
如果它按值获取参数,那么这将创建一个本地副本,并返回对该副本的引用会很糟糕,如果访问它会产生未定义的行为.
If it took the argument by value, then that would create a local copy, and returning a reference to that would be bad, giving undefined behaviour if it were accessed.
这篇关于通过引用传递时取消引用指针的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:通过引用传递时取消引用指针


基础教程推荐
- 如何将 std::pair 的排序 std::list 转换为 std::map 2022-01-01
- 如何检查GTK+3.0中的小部件类型? 2022-11-30
- C++结构和函数声明。为什么它不能编译? 2022-11-07
- 在 C++ 中计算滚动/移动平均值 2021-01-01
- 如何在 C++ 中初始化静态常量成员? 2022-01-01
- 如何通过C程序打开命令提示符Cmd 2022-12-09
- 这个宏可以转换成函数吗? 2022-01-01
- 我有静态或动态 boost 库吗? 2021-01-01
- 常量变量在标题中不起作用 2021-01-01
- 静态库、静态链接动态库和动态链接动态库的 .lib 文件里面是什么? 2021-01-01