C语言中函数传参问题

 学过c语言的都知道c语言的swap函数交换操作,那也是最早的有关函数形参和实参的介绍,以及指针的引入。

#include<stdio.h>
void swap(int a,int b)
{
	printf("a的内存%p,a的地址是%p\nb的内存%p,b的地址是%p\n",a,&a,b,&b);
}
int main()
{
	int *pa,*pb;
	int a=3,b=35;
	pa=&a;
	pb=&b;
	printf("a的内存%p,a的地址是%p\nb的内存%p,b的地址是%p\n",*pa,pa,*pb,pb);
    swap(a,b);
	
	
} 

通过结果,可以得到结论:函数传递参数过程中,若没使用指针进行传递,则系统会为保护数据自动生成所传递的参数的副本,对副本进行操作,若使用指针,则不会创建副本。

那么,如何修改指针变量的指向尼,(当然满足上述原则)

#include<stdio.h>
#include<stdlib.h>
typedef struct node *List;
struct node
{
	int data;
    struct node *next;
};
void Connect(List L);
void Connect(List L)
{
	L->data=15; 
}
int main()
{
	List L=(List)malloc(sizeof(struct node));
	L->data=10;
	L->next=NULL;
	Connect(L); 
	printf("%d",L->data);
} 

因为L副本与L数据相同,所以指向也会相同。因此可以直接修改data的值。

而下面这段代码就会出现一定问题了。

#include<stdio.h>
#include<stdlib.h>
typedef struct node *List;
struct node
{
	int data;
    struct node *next;
};
void Connect(List L);
void Connect(List L)
{
	List T=(List)malloc(sizeof(struct node));
	T->data=15;
	L=T; 
}
int main()
{
	List L=(List)malloc(sizeof(struct node));
	L->data=10;
	L->next=NULL;
	Connect(L); 
	printf("%d",L->data);
	
	
}

                                                                                                           

这里直接将L指向T所指向的,以为结果L->data=15,其实不然,你修改的只是L(副本)的指向,与L本身无关,所以需要引入指针的指针方可操作。

void Connect(List *L)
{
	List T=(List)malloc(sizeof(struct node));
	T->data=15;
	*L=T; 
}
int main()
{
	List L=(List)malloc(sizeof(struct node));
	L->data=10;
	L->next=NULL;
	Connect(&L); 
	printf("%d",L->data);
}

这样修改后,则程序不会默认给你创建副本,因此在数据结构链表有关内容时,大多采用指针的指针来传递参数。

 

以上只是本人个人见解,如果有错误的点,希望有人指出。

(虽然可能没人看,HHHHH)。

 

 

 

 

 

 

 

 

 

 

 

 

 

  • 5
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: C语言函数传参的本质是按值传递。也就是说,当调用函数时,函数的参数实际上是它们的一个副本,而不是实际的参数。当在函数内部对参数进行操作时,不会影响到函数外的实际参数的值。但是,如果在函数内部通过指针来操作参数,则可以影响到函数外的实际参数的值。 ### 回答2: C语言函数传参的本质是通过值传递来实现的。在C语言函数参数的传递方式是将实参的值复制一份给形参,在函数内部使用的是形参的值,而不是实参的值。这意味着在函数内部对形参的修改不会影响到实参的值。当函数调用结束后,形参的生命周期结束,其占用的内存会被释放。 通过值传递的方式传参还有一个特点,那就是函数内部对形参的修改不会影响到实参的值。这是因为在函数调用时,实参的值被复制给了形参,形成了两个独立的变量。虽然它们的值相同,但它们在内存的地址不同,因此对形参的修改不会反映到实参上。 需要注意的是,当传递的参数是数组或指针时,传递的是数组或指针的地址,而不是数组或指针本身的值。这意味着对数组或指针的修改是可以影响到实参的。这是因为传递的是指向数组或指针的内存地址,函数内部可以通过修改这个地址指向的内容来影响到实参。 总之,C语言函数传参的本质是通过值传递来实现的,即将实参的值复制给形参,形成两个独立的变量。这种方式可以保证函数内部对形参的修改不会影响到实参的值。 ### 回答3: C语言函数传参的本质是在函数调用时将实参的值复制给形参。当函数被调用时,实际参数的值会被复制到函数内部的形式参数,形成形参的副本。函数在执行过程使用的是这些副本,而不是实际参数本身。这意味着在函数内部对形参进行的任何修改都不会影响到实际参数的值。 在传递参数时,可以通过值传递、指针传递和引用传递三种方式来实现。值传递是指将实参的值复制给形参,由于是副本,函数内部的任何修改都不会影响到实参。指针传递是将实参的地址传递给形参,这样函数内部可以通过指针修改实参的值。引用传递是通过将实参的引用传递给形参,使得函数内部对形参的操作直接影响到实参。 传参的方式取决于所使用的参数类型和函数的要求。通常情况下,若需要修改实参的值,则使用指针传递或引用传递;若不需要修改实参的值,则使用值传递。传参的方式也会影响函数的效率和内存占用。因此,在函数调用时,需要根据具体情况选择适当的传参方式。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值