網(wǎng)站首頁 編程語言 正文
1.引用的基本用法
引用是C++對(duì)C的重要擴(kuò)充。在c/c++中,指針用法基本一致。但是C++增加了另一種給函數(shù)傳遞地址的途徑,這就是引用傳遞,也存在去其他語言,并不會(huì)是C++獨(dú)有。
1.1 引用的實(shí)質(zhì)
原類型 &別名 = 舊名
1.2 引用的用法
注意事項(xiàng):
引用一旦初始化,不能更改引用的指向
引用定義時(shí)必須初始化 不能引用NULL
引用可以引用任意類型包括數(shù)組
&在等號(hào)的左邊是引用,在等號(hào)的右邊是取地址
?代碼
#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; 引用定義時(shí)必須初始化
}
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++中可以也使用引用很好的解決這個(gè)問題
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);
}
能不能返回一個(gè)變量的引用 看這個(gè)變量的空間是否被釋放了
int & test04()
{
//能不能返回一個(gè)變量的引用 看這個(gè)變量的空間是否被釋放了
static int b = 100;
int a = 10;
//return a;//err 不能返回局部變量的引用
return b;//可以返回靜態(tài)的變量的引用
}
3.引用的本質(zhì)
引用的本質(zhì)是一個(gè)指針常量
type &b = a; 編譯器底層這么實(shí)現(xiàn)的: type *const b = &a
比如你寫
int &b = a;? // 編譯器優(yōu)化為?int * const b = &a?
4.指針的引用
套用引用公式: type &q = p
如果想改變p的內(nèi)容,函數(shù)傳遞的時(shí)候按照指針的方法傳的是地址,如下:? get_mem(&p);
如果你想用引用的方法直接傳就行
void test03()
{
? int *p = NULL;
? get_mem(&p);
? get_mem_ref(p);
}
5.常量引用
const type &p = q;
常量引用代表不能通過引用去修改引用標(biāo)識(shí)的那塊空間
int a = 10;
const int &b = a;
如果你再去? 讓 b = 1000;就是錯(cuò)誤的?
雖然不能引用常量,但是可以加const來引用
int &b = 100; //不能引用常量
改為
const int &b = 1;
原理上是 等價(jià)于,相當(dāng)于讓tmp? = 1
int tmp =1 ,const int &b= tmp;
補(bǔ)充:引用和指針的區(qū)別(重要)
從底層匯編的角度來說,引用和指針是沒有區(qū)別的,都是以存地址的方式實(shí)現(xiàn)的(了解即可)
不同點(diǎn):
- 引用概念上是定義一個(gè)變量的別名,指針是存儲(chǔ)一個(gè)變量地址。
- 引用定義的時(shí)候必須初始化,而指針沒有要求。
- 引用在初始化一個(gè)實(shí)體后,就不能再引用其他實(shí)體,但指針可以在任何時(shí)候指向任何一個(gè)同類型的實(shí)體。
- 沒有NULL引用,但有NULL指針。
- 引用比指針使用起來更安全
- 再sizeof中含義不同:引用結(jié)果為引用類型的大小,但指針始終是地址空間所占字節(jié)個(gè)數(shù)(32位平臺(tái)下是4)
- 引用自加即引用的實(shí)體增加1,指針自加即指針向后偏移一個(gè)類型的大小。
- 有多級(jí)指針,但沒有多級(jí)引用
- 訪問實(shí)體方式不同,指針需要解引用,引用的話編譯器會(huì)自己處理。
總結(jié)
原文鏈接:https://blog.csdn.net/qq_64691289/article/details/128388930
相關(guān)推薦
- 2022-02-11 SQL server 數(shù)據(jù)庫導(dǎo)入(附加)和分離 && 數(shù)據(jù)庫分離之后位置 &
- 2022-05-02 Python+Flask編寫一個(gè)簡單的行人檢測(cè)API_python
- 2023-04-26 C語言實(shí)現(xiàn)數(shù)組元素排序方法詳解_C 語言
- 2022-05-21 C++實(shí)現(xiàn)寵物商店信息管理系統(tǒng)_C 語言
- 2023-03-02 golang中new與make的區(qū)別講解_Golang
- 2022-06-20 elasticsearch索引index之merge底層機(jī)制的合并講解_相關(guān)技巧
- 2022-12-22 Nginx配置之main?events塊使用示例詳解_nginx
- 2022-08-23 React?中的列表渲染要加?key的原因分析_React
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支