c++ - 为什么将这两个代码的输出更改为 '&' 字符?

标签 c++ pointers reference dereference

第一个代码:

int a = 1;

void func(int* ptr) {
    ptr = &a;
}

int main() {
    int nvar = 2;
    int* pvar = &nvar;
    func(pvar);
    std::cout << *pvar;
}
//Output: 2

第二个代码:

int a = 1;

void func(int*& ptr) {
    ptr = &a;
}

int main() {
    int nvar = 2;
    int* pvar = &nvar;
    func(pvar);
    std::cout << *pvar;
}
//Output: 1

唯一的区别是“func”函数中的“&”字符。但是有人可以向我解释一下,它在这种情况下会做什么吗?

最佳答案

I know what it does, but in the second code it is combined with * , and I dont know what this combination means

T& 表示“对T 的引用”。

现在将 T 替换为您喜欢的任何内容。例如,对于指向 int 的指针,T==int* 我们有 int*&,它是对指向 int< 的指针的引用.

这与将非指针作为引用传递给函数没有什么不同。当 ptr 通过值传递时,func 作用于一个拷贝,当通过引用传递时,func 作用于传入的实例。

关于c++ - 为什么将这两个代码的输出更改为 '&' 字符?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58700183/

相关文章:

c++ - 通过引用或指针返回并检查是否为空?

c++ - 在 C++ 中使用 vector 实现简单的优先级队列

c++ - 高效的 const char* 连接和输出到 std::string

c - 解引用指针并为其分配值

c++ - 尝试将派生类对象地址分配给基类指针 vector

c++ - 在与 Odeint 结合的类中使用特征矩阵引用

c++ - 在 Solaris10 上使用 g++ 进行 64 位编译

c++ - g++ 4.8.5 : does not give a valid preprocessing token using ##

c - 解释使用void指针的区别

c++ - 是否通过名称和定义明确的引用在表达式中多次修改对象?