函数无目的地更改引用
Function changes reference without purpose
我有一个代码:
Node** ptrlow = ReturnLowest(root); ///pointer po pointer pointing lowest
//DeleteNode(ptrlow);
Test(ptrlow);
我认为这段代码的作用并不重要,重要的是,当我意识到函数 DeleteNode(Node** &node) 毫无目的地更改 ptrlow 的值时,我创建了名为 Test 的函数:
void Test(Node** &node)
{
return;
}
这实际上是整个函数,它什么都不做,但它改变了 ptrlow 的值,该值被传递给该函数。
在进入测试功能之前: 从视觉工作室链接到屏幕 输入后: 从视觉工作室链接到屏幕 在调试器中再走一步,节点就会发生变化: 从视觉工作室链接到屏幕
有人可以向我解释这怎么可能吗?我将不胜感激!
在最后一张图片上,调试器超出了函数的范围,因此传递的参数应该已经被丢弃(node
不再存在)。
正如预期的那样,Node** ptrlow
的值保持不变。
我知道它应该保持不变,但是看,它确实发生了变化: 将此屏幕与第一个屏幕进行比较
我试着放一些代码行,DeleteNode函数,有很多。
开头的删除节点函数
DeleteNode 功能更进一步;节点已更改
相关文章:
- 将对象数组的引用传递给函数
- 什么时候在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*)的指针
- 向量元素的引用地址与它所指向的向量元素的地址不同.为什么
- 具有默认值的引用获取函数
- 如何使用基类指针引用派生类成员
- 使用取消引用的指针的多态性会产生意外的结果.为什么?
- 函数无目的地更改引用