1引用的定義
引用時c++對c的乙個重要的擴充,引用的作用是給變數起乙個別名。
例如:int a;
int &b=a;//宣告b是a的引用
經過以上的宣告,b就成為了a的別名,a和b的地位以及作用都是一樣的。
將b宣告為a的引用,不需要再為b開闢新的單元,b和a在記憶體中佔同一儲存單元,它們具有相同的位址。
複製** **如下:
#include
using namespace std;
int main()
在程式中,
宣告了b是a的引用,然後輸出b=10;
然後使a的值減小5,再輸出b=5,說明b會隨著a的變化做出變化;
然後使b的值減小1,再輸出a=4,說明a會隨著b的變化做出變化。
在宣告乙個引用的同時,必須同時對它進行初始化,即宣告它代表哪乙個變數。在宣告變數b是變數a的引用後,就可以將b作為a的別名來進行操作,並且b不能再作為其他變數的引用(別名)。
宣告引用,而不進行初始化操作:
複製** **如下:
#include
using namespace std;
int main()
編輯器報錯
****************************************
已經申明p為a的引用之後,在宣告p為b的引用
複製** **如下:
#include
using namespace std;
int main()
編輯器報錯:
注意區分:
int &b=a;表示b是a的引用
int *b=&a;表示b是指標變數,並且b的值是a的位址
引用不是一種獨立的資料型別,必須指定其代表的某一類實體(如變數,類物件),不能定義引用陣列,不能定義指向引用的指標,也不能定義指標的引用。
2 引用作為函式的引數
c++增加引用機制,主要是把它作為函式引數,以擴充函式傳遞資料的功能。
函式的引數傳遞有三種情況
將變數名作為形參和實參
這是傳給形參的是變數的值,傳遞是單向的。如果在執行被呼叫函式期間,形參的值發生變化,是不能反映到實參的。因為形參只是複製了實參的數值,兩變數並不是占用同一儲存單元。
複製** **如下:
#include
using namespace std;
int main()
void change(int x,int y)
x複製了i的值,y複製了j的值。但i和j與x和y佔不同的儲存單元,因此只改變x和y的值,並不能改變i和j的值。
將變數位址作為實參,指標作為形參
這種方式仍然是值傳遞的方式,不過他傳遞的不是變數的數值,而是變數的位址。因此可以在被呼叫函式中,通過呼叫指標指向的變數來改變相應變數的值。
複製** **如下:
#include
using namespace std;
int main()
void change(int * x,int * y)
因為是值傳遞,所以只改變指標的值,而不去改變指向的變數的值,還是不能改變相應的變數的值。
複製** **如下:
#include
using namespace std;
int main()
void change(int * x,int * y)
當改變指標指向的變數的值的時候,相應的變數的數值也會發生變化。
將變數名作為實參,引用作為形參
將變數名作為形參和實參和將變數位址作為實參,指標作為形參都是採用的值傳遞的方式。而引用作為形參的時候,採用的是位址傳遞的方式。
複製** **如下:
#include
using namespace std;
int main()
void change(int & x,int & y)
在函式change的形參中宣告了a,b是整形變數的引用。當main函式呼叫change函式時,把實參i的位址傳遞給形參x,把實參j的位址傳遞給形參y,從而使i和x共享同乙個單元,使j和y共享同乙個單元。也可以理解成,把i的變數名傳遞給了x,把j的變數名傳遞給了y。
引用作為形參與指標變數作為形參的區別
1使用引用型別,就不必在swap函式中宣告形參是指標變數。指標變數要另外開闢記憶體單元,其內容是位址。而引用不是乙個獨立的變數,不單獨佔記憶體單元,引用的gmrmaoock資料型別應該應該與實參相同。
2 在main函式中,實參不必用變數的位址,而是直gmrmaoock接用變數名。系統向形參傳遞的是實參的位址而不是實參的值。
3 由於不能宣告指標的引用,那我們如何像指標那樣傳遞可以通過傳遞陣列的首元素來實現傳遞整個陣列的資料呢?
使用指標作為形參:
複製** **如下:
#include
using namespace std;
int main();
print(a,5);
return 0;
}void print(int *p,int n)
}使用引用作為形參
複製** **如下:
#include
using namespace std;
int main();
print(a[0],5);
return 0;
}void print(int &p,int n)
}因為引用就是給原來的變數起了別名,並且不能宣告指標的引用,所以我們就宣告指標指向的變數的引用,然後再對引用取位址,就達到了這個目的。
為了更清楚的說明,下面再舉乙個例子:
複製** **如下:
#include
using namespace std;
int main()
複製** **如下:
#include
using namespace std;
int main();
int &y=a[0];//宣告y作為陣列的首元素的引用
int *p=&y;//將y的位址賦給指標p
int i=0;
for(;i<5;i++)
return 0;
}本文標題: c++中引用的使用總結
本文位址:
關於c 中的引用總結
1 在引用的使用中,單純給某個變數取個別名是毫無意義的,引用的目的主要用於在函式引數傳遞中,解決大塊資料或物件的傳遞效率和空間不如意的問題。2 用引用傳遞函式的引數,能保證引數傳遞中不產生副本,提高傳遞的效率,且通過const的使用,保證了引用傳遞的安全性。3 引用與指標的區別是,指標通過某個指標變...
c 中引用符合的使用
對乙個資料建立乙個 引用 他的作用是為乙個變數起乙個別名。這是c 對c語言的乙個重要補充。如何建立乙個引用 int a 5 int b a cout以上宣告了b是a的引用,並把a,b的值和它們的位址列印出來。經過宣告後b是a別名,b與a代表的是同乙個變數,佔記憶體中同乙個儲存單元,具有同一位址。注意...
C 中引用符號「 」的作用總結
今天在寫程式中用到了運算子過載,為了方便地輸出vector容器中的元素,我過載了 運算子。我是這麼寫的 templatestd ostream operator std ostream s,const std vector v 為在程式中呼叫該函式,則相應的主調函式的呼叫點處,直接以變數作為實參進行...