C++中引用處理的基本方法
1.引用的基本用法
引用是C++對C的重要擴(kuò)充。在c/c++中,指針用法基本一致。但是C++增加了另一種給函數(shù)傳遞地址的途徑,這就是引用傳遞,也存在去其他語言,并不會是C++獨有。
1.1 引用的實質(zhì)
原類型 &別名 = 舊名
1.2 引用的用法
注意事項:
引用一旦初始化,不能更改引用的指向
引用定義時必須初始化 不能引用NULL
引用可以引用任意類型包括數(shù)組
&在等號的左邊是引用,在等號的右邊是取地址
代碼
#include <iostream> using namespace std; void test01() { int a = 10; int& b = a; b = 100; cout << a << endl; int c = 1; //b = c; 代表把c的值賦值給b 不是給c取別名為b //int &d; 引用定義時必須初始化 } void test02() { int a[5] = { 1,2,3,4,5 };//int(&arr)[5] = a; typedef int ARR[5]; //type & 別名 = 舊名 ARR & arr = a; for (int i = 0; i < 5; i++) { cout << arr[i] << " "; } cout << endl; } int main() { test02(); return 0; }
2.函數(shù)中的引用
引用可以作為函數(shù)的形參 ,不能返回局部變量的引用
在C語言中我們記得我們可以用指針解決函數(shù)不能交換值的問題。
swap(int *x ,int *y) { int temp = *x; *x = *y; *y = temp; } void test01() { int a = 10; int b = 20; swap(&a,&b); }
在C++中可以也使用引用很好的解決這個問題
void swap_ref(int &x, int &y)// int &x =a, int &y =b { int tmp = x; x = y; y = tmp; } void test01_ref() { int a = 10; int b = 20; swap_ref(a, b); }
如果想開辟數(shù)組地址,用指針的做法是
//形參是指針 引用 void get_mem(int **q) { *q = (int *)malloc(5 * sizeof(int)); } void test03() { int *p = NULL; get_mem(&p); get_mem_ref(p); }
用引用可以這樣做
void get_mem_ref(int * &q)//int * (&q) = p { q = (int *)malloc(5 * sizeof(int)); } void test03() { int *p = NULL; get_mem(&p); get_mem_ref(p); }
能不能返回一個變量的引用 看這個變量的空間是否被釋放了
int & test04() { //能不能返回一個變量的引用 看這個變量的空間是否被釋放了 static int b = 100; int a = 10; //return a;//err 不能返回局部變量的引用 return b;//可以返回靜態(tài)的變量的引用 }
3.引用的本質(zhì)
引用的本質(zhì)是一個指針常量
type &b = a; 編譯器底層這么實現(xiàn)的: type *const b = &a
比如你寫
int &b = a; // 編譯器優(yōu)化為 int * const b = &a
4.指針的引用
套用引用公式: type &q = p
如果想改變p的內(nèi)容,函數(shù)傳遞的時候按照指針的方法傳的是地址,如下: get_mem(&p);
如果你想用引用的方法直接傳就行
void test03() { ? int *p = NULL; ? get_mem(&p); ? get_mem_ref(p); }
5.常量引用
const type &p = q;
常量引用代表不能通過引用去修改引用標(biāo)識的那塊空間
int a = 10; const int &b = a;
如果你再去 讓 b = 1000;就是錯誤的
雖然不能引用常量,但是可以加const來引用
int &b = 100; //不能引用常量
改為
const int &b = 1;
原理上是 等價于,相當(dāng)于讓tmp = 1
int tmp =1 ,const int &b= tmp;
補(bǔ)充:引用和指針的區(qū)別(重要)
從底層匯編的角度來說,引用和指針是沒有區(qū)別的,都是以存地址的方式實現(xiàn)的(了解即可)
不同點:
- 引用概念上是定義一個變量的別名,指針是存儲一個變量地址。
- 引用定義的時候必須初始化,而指針沒有要求。
- 引用在初始化一個實體后,就不能再引用其他實體,但指針可以在任何時候指向任何一個同類型的實體。
- 沒有NULL引用,但有NULL指針。
- 引用比指針使用起來更安全
- 再sizeof中含義不同:引用結(jié)果為引用類型的大小,但指針始終是地址空間所占字節(jié)個數(shù)(32位平臺下是4)
- 引用自加即引用的實體增加1,指針自加即指針向后偏移一個類型的大小。
- 有多級指針,但沒有多級引用
- 訪問實體方式不同,指針需要解引用,引用的話編譯器會自己處理。
總結(jié)
到此這篇關(guān)于C++中引用處理的文章就介紹到這了,更多相關(guān)C++引用處理內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++實現(xiàn)學(xué)生成績管理系統(tǒng)最新版
這篇文章主要為大家詳細(xì)介紹了C++實現(xiàn)學(xué)生成績管理系統(tǒng)最新版,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-06-06C/C++標(biāo)準(zhǔn)庫之轉(zhuǎn)換UTC時間到local本地時間詳解
最近遇到一個問題:數(shù)據(jù)庫中存放的時間為UTC時間,但是現(xiàn)在要求都出來顯示的時間為本地時間,所以就用C++實現(xiàn)了,下面這篇文章主要給大家介紹了關(guān)于C/C++標(biāo)準(zhǔn)庫之轉(zhuǎn)換UTC時間到local本地時間的方法,還有C++中獲取UTC時間精確到微秒的實現(xiàn)代碼,需要的朋友可以參考下。2017-11-11