当你有这样的函数时,形式参数是一个引用,它成为实际参数的另一个名称,这样当我们修改函数内部的形式参数时,函数外部的原始变量就会改变。
void add_five(int& a)
{
a += 5;
}
int main()
{
int number = 3;
add_five(number);
std::cout << number << std::endl; // prints 8
return 0;
}
我有一些代码可以在链表上工作。我正在将两个Node*
s传递给函数。
void LinkedList::move_five_nodes(Node* ptr1, Node* ptr2) { ... }
...
void LinkedList::anotherFunction()
{
Node* leader;
Node* trailer;
...
move_five_nodes(leader, trailer);
...
}
我认为leader
和trailer
指针变量中的rvalues内存addreses将被分配到Node*
左值ptr1
和ptr2
。
Node* ptr1 = leader;
Node* ptr2 = trailer;
问题是ptr1
和ptr2
是函数内部的独立局部变量。最初,它们指向与实际参数指针相同的位置。但是,我的函数会移动一些节点,并且在函数的末尾,ptr1
和ptr2
的值会发生变化。我希望这些更改也可以在原始变量leader
和trailer
中,就像引用一样。因此,即使ptr1
和ptr2
到期,leader
和trailer
应该进入他们的位置。
我该怎么做?也许键入指针到int&
?或者可能使用指针指针?我想通过引用传递指针,但我不知道该怎么做。
我想通过引用传递指针,但我不知道该怎么做。
为此,请考虑以下代码段
#include <iostream>
void test(int*& t)
{
t = nullptr;
}
int main()
{
int* i = new int(4);
test(i);
if (i == nullptr)
std::cout << "I was passed by reference" << std::endl;
}
其中是通过引用传递给test,其中它被设置为nullptr并且程序打印:I was passed by reference
。
我认为这个例子应该明确如何通过引用函数传递指针。
因此,在您的情况下,函数签名必须更改为
void LinkedList::move_five_nodes(Node*& ptr1, Node*& ptr2) { ... }