LinkList L 与LinkList &L(LNode* L , LNode* &L)的区别

文章讨论了在C语言中定义和操作单链表时,使用普通指针和引用传递参数的差异。通过`update_1`和`update_2`两个函数的例子,说明了当传入指针变量时,直接对指针重新分配内存不会影响原指针所指向的对象,而传入引用则会改变原指针指向的新对象。这涉及到指针的复制和引用的别名特性。
摘要由CSDN通过智能技术生成

1,先定义一个单链表结构体

typedef struct LNode 
{ 
    int data; 
    struct LNode *next; 
}LNode, *LinkList ;    //LNode,*LinkList均为LNode的别名,只不过是一个主要指代结点一个指代链表。

2,定义两个分别以LinkList L 和LinkList &L为参数的方法

void update_1(LinkList L1)
{ 
    L1 = (LinkList)malloc(sizeof(LNode)); 
    L1->data = 1; 
} 
void update_2(LinkList &L2) 
{ 
    L2 = (LinkList)malloc(sizeof(LNode)); 
    L2->data = 1; 
}

3,分别调用两个方法,看传入参数写法不同时的不同效果

可见调用update_1修改第一个结点的值,而update_2修改了。

原因:

LinkList L1 是定义了一个指针变量L1,当传入一个指针变量L时,是将指针变量L此时的地址赋值给临时指针变量L1。让L1与L指向同一位置,给L1分配一个新的地址并赋值,并不影响指针L所指向地址的值。

LinkList &L2 是给传入的指针变量的L起一个别名叫L2,(L即L2,L2即L),所以给L2分配了一个新空间并赋值为1,就相当于给L分配了一个新空间并赋值为1。(就比如你的大名叫皮皮,小名叫小皮,现在给皮皮100元,那是不是就也可以说小皮有100元)。

注:

LNode* L , LNode* &L 就相当于LinkList L 和LinkList &L,是一样的。(LNode表示值,而LNode* 就与LinkList一样了表示指针变量)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

HHHzy0903

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值