c語言的形參和實參傳遞的區(qū)別詳解
參數(shù)傳遞,是在程序運行過程中,實際參數(shù)就會將參數(shù)值傳遞給相應(yīng)的形式參數(shù),然后在函數(shù)中實現(xiàn)對數(shù)據(jù)處理和返回的過程。參數(shù)傳遞有3種方式:
- 值傳遞
- 地址傳遞
- 引用傳遞
tips:
- 被調(diào)用函數(shù)的形參只有函數(shù)被調(diào)用時才會臨時分配存儲單元,一旦調(diào)用結(jié)束占用的內(nèi)存便會被釋放
- 值傳遞和地址傳遞,傳遞的都是實參的一個拷貝
- C語言中實參和形參之間的數(shù)據(jù)傳遞是單向的“值傳遞”,單向傳遞,只能由實參傳給形參,反之不行
- 輸出格式并沒有選擇%p而是選擇了%d,因為十進制的數(shù)看起來更直觀
1 值傳遞
如果只是傳遞值的話:
#include <stdio.h>
//值傳遞:傳值
void swap( int x, int y);
int main()
{
int a=2,b=3;
printf("before:實參為a,b\na=%d,地址為%d\nb=%d,地址為%d\n\n",a,&a,b,&b);
swap(a,b);
printf("after:實參為a,b\na=%d,地址為%d\nb=%d,地址為%d\n\n",a,&a,b,&b);
return 0;
}
void swap(int x,int y)
{
int tmp;
tmp=x;
x=y;
y=tmp;
printf("inside:形參為x,y\nx=%d,地址為%d\ny=%d,地址為%d\n\n",x,&x,y,&y);
}
執(zhí)行結(jié)果:從形參x和y的地址來看,傳遞的是實參a和b的拷貝。對拷貝的修改不會改變實參的值。。

如果值傳遞,傳遞的是地址呢?
#include <stdio.h>
//值傳遞:傳地址
void swap( int *x, int *y);
int main()
{
int a=2,b=3;
printf("before:實參為&a,&b\na=%d,地址為%d\nb=%d,地址為%d\n\n",a,&a,b,&b);
swap(&a,&b);
printf("after:實參為&a,&b\na=%d,地址為%d\nb=%d,地址為%d\n\n",a,&a,b,&b);
return 0;
}
void swap(int *x,int *y)
{
int *tmp= NULL;
tmp=x;
x=y;
y=tmp;
printf("inside:形參為*x,*y\n*x=%d,x=%d,地址為%d\n*y=%d,y=%d,地址為%d\n\n",*x,x,&x,*y,y,&y);
}
執(zhí)行結(jié)果:形參是a和b的地址,但通過a和b的地址(即x和y)訪問到的是a和b的拷貝。直接交換a和b的地址失敗。

2地址傳遞
#include <stdio.h>
//地址傳遞
void swap( int *x, int *y);
int main()
{
int a=2,b=3;
printf("before:實參為&a,&b\na=%d,地址為%d\nb=%d,地址為%d\n\n",a,&a,b,&b);
swap(&a,&b);
printf("after:實參為&a,&b\na=%d,地址為%d\nb=%d,地址為%d\n\n",a,&a,b,&b);
return 0;
}
void swap(int *x,int *y)
{
int tmp;
tmp=*x;
*x=*y;
*y=tmp;
printf("inside:形參為*x,*y\n*x=%d,x=%d,地址為%d\n*y=%d,y=%d,地址為%d\n\n",*x,x,&x,*y,y,&y);
}
執(zhí)行結(jié)果為: 形參是a和b的地址,但通過a和b的地址(即x和y)訪問到的是a和b的拷貝。雖然不能直接交換a和b的地址,但是可以修改a和b的地址(即x和y)指向的值。也就是說,不能直接修改指針,但是可以修改指針指向的值。所以這一次a和b的值交換了。

3 引用傳遞
#include <stdio.h>
//引用傳遞
void swap( int &x, int &y);
int main()
{
int a=2,b=3;
printf("before:實參為a,b\na=%d,地址為%d\nb=%d,地址為%d\n\n",a,&a,b,&b);
swap(a,b);
printf("after:實參為a,b\na=%d,地址為%d\nb=%d,地址為%d\n\n",a,&a,b,&b);
return 0;
}
void swap(int &x,int &y)
{
int tmp;
tmp=x;
x=y;
y=tmp;
printf("inside:形參為&x,&y\nx=%d,地址為%d\ny=%d,地址為%d\n\n",x,&x,y,&y);
}
void swap( int &x, int &y); //表示傳遞進去的是實參,而不是拷貝。
執(zhí)行結(jié)果為: 傳遞的是實參,而不是實參的拷貝。對實參的修改,將會成功的改變其中的值。

補充
int x=1;
int *y=&x; //用于指針傳遞,y有自己獨立的內(nèi)存地址,存儲的內(nèi)容是x的地址,*y是x的值
int &z=x; //用于引用傳遞,可以理解為z就是x,x就是z,只不過名字不一樣
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C++關(guān)鍵字volatile學(xué)習(xí)筆記
這篇文章主要為大家介紹了C++關(guān)鍵字volatile學(xué)習(xí)筆記,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-10-10
C語言實現(xiàn)學(xué)生信息管理系統(tǒng)(多文件)
這篇文章主要為大家詳細(xì)介紹了C語言實現(xiàn)學(xué)生信息管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-12-12
C++實現(xiàn)leetcode(3.最長無重復(fù)字符的子串)
這篇文章主要介紹了C++實現(xiàn)leetcode(3.最長無重復(fù)字符的子串),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07

