链表C++中的内存地址

Memory address in linked list C++

我用C++创建了一个极其简单的链表例子来练习一些面试题。我遇到了一个我似乎无法真正理解的奇怪问题:

while( cur )
{
    cout << "Index: " << indx << endl <<
        "Current Add:\t" << &cur << endl <<
        "Value:\t\t" << cur->val << endl <<
        "Next Add:\t" << &cur->next << endl << 
        "Ran Add:\t" << &cur->ran << endl <<
        "Ran Val:\t" << cur->ran->val << endl << endl;
    cur = cur->next;
    ++indx;
}

我正在使用此代码遍历并打印列表。它工作正常。然而。当前节点的地址始终相同。该列表包含一个 int 值和一个指向下一个节点的指针以及一个指向列表中随机地址的指针。地址和值分配正确,我可以看到 "next" 地址正常。但是当它将它分配给当前节点时,它似乎总是指向相同的地址..

我唯一可以假设的是,在执行期间它会将 "cur" 移动到某个寄存器,因此始终显示此地址而不是内存中的位置。这有意义吗?这是正确的还是我遗漏了什么?这不会以任何方式影响我的实现,这只是我想更好地理解的一些奇怪行为。

谢谢

您正在打印:

"Current Add:\t" << &cur << endl <<

这是变量的地址:

struct node *cur;

那个指针的地址(不是它指向的地址!)当然不会改变。您可能打算写:

"Current Add:\t" << cur << endl <<