链表头指针head要设为**head,而不是*head

这篇博客深入探讨了C++中如何使用指针引用在链表插入(push)操作中的工作原理。通过示例代码,解释了如何通过指针的地址来修改外部变量的值,特别是当需要更新链表头节点时。文章强调了在函数参数传递中,对于指针类型需要使用引用以确保能够正确修改原始指针。内容涵盖了指针、引用、链表节点的创建及链接过程。
摘要由CSDN通过智能技术生成

用以下的代码作为示例,解释。

 

struct Node* head = NULL;
void push(struct Node** head_ref, int new_data)
{
    /* allocate node */
    struct Node* new_node = new Node();
 
    /* put in the data */
    new_node->data = new_data;
 
    /* link the old list off the new node */ 
    new_node->next = (*head_ref);
 
    /* move the head to point to the new node */
    (*head_ref) = new_node;
}
在这里每次修改的都是指针指向的地址。

1)在函数里想要修改外部一个变量的值,实参是通过引用传递,也就是传地址,传的是变量的地址。
形参的接收方式 
eg :int modify(int * i)
      
2)在函数里想要修改一个指针时,那么也通过引用传递, 还是传地址,只是在这里,传递的是一个指向指针的地址。


总结: 在上面的代码中,在Push节点时, *head_ref 都要改变,所以形参接收的是指向指针的地址。

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值