C++關(guān)于const與引用的分析講解
一、關(guān)于 const 的疑問
const 什么時(shí)候?yàn)橹蛔x變量?什么時(shí)候是常量?
const 常量的判別準(zhǔn)則
- 只有用字面量初始化的 const 常量才會進(jìn)入符號表
- 使用其他變量初始化的 const 常量仍然是只讀變量
- 被 volatile 修飾的 const 常量不會進(jìn)入符號表
注:在編譯期間不能直接確定初始值的 const 標(biāo)識符,都被作為只讀變量處理。
const 引用的類型與初始化變量的類型 如果相同,則初始化變量成為只讀變量;如果不同 ,則生成一個(gè)新的只讀變量。
下面看一段 const 典型問題分析的代碼:
#include <stdio.h> int main() { const int x = 1; const int& rx = x; int& nrx = const_cast<int&>(rx); nrx = 5; printf("x = %d\n", x); printf("rx = %d\n", rx); printf("nrx = %d\n", nrx); printf("&x = %p\n", &x); printf("&rx = %p\n", &rx); printf("&nrx = %p\n", &nrx); volatile const int y = 2; int* p = const_cast<int*>(&y); *p = 6; printf("y = %d\n", y); printf("p = %p\n", p); const int z = y; p = const_cast<int*>(&z); *p = 7; printf("z = %d\n", z); printf("p = %p\n", p); char c = 'c'; char& rc = c; const int& trc = c; rc = 'a'; printf("c = %c\n", c); printf("rc = %c\n", rc); printf("trc = %c\n", trc); return 0; }
下面為輸出結(jié)果:
第一個(gè)需要注意的地方就是 使用字面量初始化的 const 常量才會進(jìn)入符號表,所以打印出的x的值為1,而不是5。rx 代表的是 C++ 編譯器為 x 常量分配但是沒有使用的空間,為只讀變量。const_cast 消除了只讀變量的只讀屬性,所以得到的 nrx 為一個(gè)普通變量,且 nrx 也代表一個(gè)內(nèi)存空間,這段內(nèi)存空間與 rx 代表的內(nèi)存空間為同一段。所以運(yùn)行后 x,rx以及 nrx 所代表的的地址都是一樣。
第二個(gè)需要注意的地方就是被 volatile 修飾的 const 常量不會進(jìn)入符號表,所以修飾的常量為只讀變量。const_cast 消除了 y 地址的只讀屬性,所以可以用一個(gè)普通指針 p 指向 y 的地址,所以改變 p 指針里面的內(nèi)容,y 的值也會改變。
第三個(gè)需要注意的地方就是使用其他變量初始化的 const 常量仍然是只讀變量。所以令 const int z = y 后,依然可以使用指針改變 z 的值。
第四個(gè)需要注意的地方就是const 引用的類型與初始化變量的類型 如果相同,則初始化變量成為只讀變量;如果不同 ,則生成一個(gè)新的只讀變量。所以 trc 的值和上面的 c 和 rc不一樣。
二、關(guān)于引用的疑問
引用與指針有什么關(guān)系?如何理解“引用的本質(zhì)就是指針常量”?
指針是一個(gè)變量
- 值為一個(gè)內(nèi)存地址,不需要初始化,可以保存不同的地址
- 通過指針可以訪問對應(yīng)內(nèi)存地址中的值
- 指針可以被 const 修飾成為常量或者只讀變量
引用只是一個(gè)變量的新名字
- 對引用的操作(賦值,取地址等)都會傳遞到代表的變量上
- const 引用使其代表的變量具有只讀屬性
- 引用必須在定義時(shí)初始化,之后無法代表其它變量
從使用 C++ 語言的角度來看
- 引用與指針沒有任何的關(guān)系
- 引用是變量的新名字,操作引用就是操作對應(yīng)的變量
從 C++ 編譯器的角度來看
- 為了支持新概念“引用”必須要一個(gè)有效的解決方案
- 在編譯器內(nèi)部,使用指針常量來實(shí)現(xiàn)“引用”
- 因此“引用”在定義時(shí)必須初始化
在工程項(xiàng)目開發(fā)中
- 當(dāng)進(jìn)行 C++ 編程時(shí),直接站在使用的角度看待引用,與指針毫無關(guān)系,引用就是變量的別名
- 當(dāng)對 C++ 代碼進(jìn)行調(diào)試分析時(shí),一些特殊情況,可以考慮站在C++編譯器的角度看待引用
下面看一段引用典型問題分析:
#include <stdio.h> int a = 1; struct SV { int& x; int& y; int& z; }; int main() { int b = 2; int* pc = new int(3); SV sv = {a, b, *pc}; //int& array[] = {a, b, *pc}; // &array[1] - &array[0] = ? Expected ==> 4 printf("&sv.x = %p\n", &sv.x); printf("&sv.y = %p\n", &sv.y); printf("&sv.z = %p\n", &sv.z); delete pc; return 0; }
下面為輸出結(jié)果:
在C語言和 C++ 中數(shù)組的地址都是遞增的,而在該代碼中可以看到第1個(gè)元素的地址減去第二個(gè)元素的地址不為4,所以說明C++中不支持引用數(shù)組。
三、小結(jié)
- 指針是一個(gè)變量
- 引用是一個(gè)變量的新名字
- const 引用能夠生成新的只讀變量
- 在編譯器內(nèi)部使用指針常量實(shí)現(xiàn)“引用”
- 編譯時(shí)不能直接確定初始值的 const 標(biāo)識符都是只讀變量
到此這篇關(guān)于C++關(guān)于const與引用的分析講解的文章就介紹到這了,更多相關(guān)C++const與引用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
c++中關(guān)于max_element()函數(shù)解讀
這篇文章主要介紹了c++中關(guān)于max_element()函數(shù)解讀,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02一起來學(xué)習(xí)C++的動態(tài)內(nèi)存管理
這篇文章主要為大家詳細(xì)介紹了C++的動態(tài)內(nèi)存管理,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-03-03對C語言中sizeof細(xì)節(jié)的三點(diǎn)分析介紹
以下是對C語言中sizeof的細(xì)節(jié)進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以參考下2013-07-07iostream與iostream.h的區(qū)別詳細(xì)解析
以下是對C++中iostream與iostream.h的區(qū)別進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過來參考下2013-09-09C++ OpenCV實(shí)現(xiàn)抖音"藍(lán)線挑戰(zhàn)"特效
這篇文章主要介紹了如何使用OpenCV C++ 實(shí)現(xiàn)抖音上的特效“藍(lán)線挑戰(zhàn)”。文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)OpenCV有一定的幫助,需要的可以參考一下2022-01-01