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

如果值傳遞,傳遞的是地址呢?
#include <stdio.h>
//值傳遞:傳地址
void swap( int *x, int *y);
int main()
{
int a=2,b=3;
printf("before:實(shí)參為&a,&b\na=%d,地址為%d\nb=%d,地址為%d\n\n",a,&a,b,&b);
swap(&a,&b);
printf("after:實(shí)參為&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的地址,但通過(guò)a和b的地址(即x和y)訪問(wèn)到的是a和b的拷貝。直接交換a和b的地址失敗。

2地址傳遞
#include <stdio.h>
//地址傳遞
void swap( int *x, int *y);
int main()
{
int a=2,b=3;
printf("before:實(shí)參為&a,&b\na=%d,地址為%d\nb=%d,地址為%d\n\n",a,&a,b,&b);
swap(&a,&b);
printf("after:實(shí)參為&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的地址,但通過(guò)a和b的地址(即x和y)訪問(wèn)到的是a和b的拷貝。雖然不能直接交換a和b的地址,但是可以修改a和b的地址(即x和y)指向的值。也就是說(shuō),不能直接修改指針,但是可以修改指針指向的值。所以這一次a和b的值交換了。

3 引用傳遞
#include <stdio.h>
//引用傳遞
void swap( int &x, int &y);
int main()
{
int a=2,b=3;
printf("before:實(shí)參為a,b\na=%d,地址為%d\nb=%d,地址為%d\n\n",a,&a,b,&b);
swap(a,b);
printf("after:實(shí)參為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); //表示傳遞進(jìn)去的是實(shí)參,而不是拷貝。
執(zhí)行結(jié)果為: 傳遞的是實(shí)參,而不是實(shí)參的拷貝。對(duì)實(shí)參的修改,將會(huì)成功的改變其中的值。

補(bǔ)充
int x=1;
int *y=&x; //用于指針傳遞,y有自己獨(dú)立的內(nèi)存地址,存儲(chǔ)的內(nèi)容是x的地址,*y是x的值
int &z=x; //用于引用傳遞,可以理解為z就是x,x就是z,只不過(guò)名字不一樣
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C++實(shí)現(xiàn)LeetCode(8.字符串轉(zhuǎn)為整數(shù))
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(8.字符串轉(zhuǎn)為整數(shù)),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07
C++實(shí)現(xiàn)LeetCode(71.簡(jiǎn)化路徑)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(71.簡(jiǎn)化路徑),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07
C語(yǔ)言循環(huán)語(yǔ)句之重復(fù)執(zhí)行特定的代碼塊
在C語(yǔ)言中分支和循環(huán)語(yǔ)句是實(shí)現(xiàn)條件執(zhí)行和重復(fù)執(zhí)行的重要工具,下面這篇文章主要給大家介紹了關(guān)于C語(yǔ)言循環(huán)語(yǔ)句之重復(fù)執(zhí)行特定的代碼塊的相關(guān)資料,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-01-01
QT5中使用QRegularExpression代替QRegExp方法代碼
這篇文章主要給大家介紹了關(guān)于QT5中使用QRegularExpression代替QRegExp的相關(guān)資料,正則表達(dá)式(regep)是處理字符串和文本的強(qiáng)大工具,驗(yàn)證regexp可以測(cè)試子字符串是否滿足某些條件,例如是整數(shù)或不包含空格,需要的朋友可以參考下2024-04-04
將正小數(shù)轉(zhuǎn)化為2-9進(jìn)制小數(shù)的實(shí)現(xiàn)方法
本篇文章對(duì)正小數(shù)轉(zhuǎn)化為2-9進(jìn)制小數(shù)的實(shí)現(xiàn)方法進(jìn)行了介紹,需要的朋友參考下2013-05-05
VS2019+MPI配置過(guò)程的實(shí)現(xiàn)步驟
本文介紹了在VS2019上配置MPI,包括下載和安裝MPI、創(chuàng)建項(xiàng)目、配置屬性、導(dǎo)入頭文件和庫(kù)文件、添加依賴項(xiàng)等步驟,具有一定的參考價(jià)值,感興趣的可以了解一下2024-12-12
C++ Leetcode實(shí)現(xiàn)從英文中重建數(shù)字
本文主要介紹了當(dāng)給你一個(gè)字符串s,其中包含字母順序打亂的用英文單詞表示的若干數(shù)字(0-9)時(shí),如何通過(guò)Leetcode按升序返回原始的數(shù)字。感興趣的童鞋可以來(lái)看看2021-11-11

