C++ const關(guān)鍵字的實(shí)例用法
C++中的const更像編譯階段的#define
const int m = 10; int n = m;
變量是要占用內(nèi)存的,即使被const修飾也不例外。m,n兩個(gè)變量占用不同的內(nèi)存,int n = m;表示將m的值賦給n。
- 在C語(yǔ)言中,編譯器會(huì)先到m所在的內(nèi)存取出一份數(shù)據(jù),再將這份數(shù)據(jù)賦給n;
- 在C++中,編譯器會(huì)直接將10賦給m,沒(méi)有讀取內(nèi)存的過(guò)程,和int n = 10效果一樣。
- 在C++中的常量更類似于#define命令,是一個(gè)值替換的過(guò)程,只不過(guò)#define是在預(yù)處理階段替換,而常量是在編譯階段替換。
C++中的const
- 優(yōu)點(diǎn):提高了程序執(zhí)行效率
- 缺點(diǎn):不能反映內(nèi)存的變化,一旦const變量被修改,C++就不能取得最新的值。
const變量禁止被修改 --- 只是語(yǔ)法層面上的限制,通過(guò)指針仍然可以修改。
#include <stdio.h>
int main(){
const int n = 10;
//注意:&n得到的指針的類型是const int*,必須強(qiáng)制轉(zhuǎn)換為int*后才能賦給p,否則類型是不兼容的。
int *p = (int*)&n; //必須強(qiáng)制類型轉(zhuǎn)換
*p = 99; //修改const變量的值
printf("%d\n", n);
return 0;
}
//以C語(yǔ)言的方式編譯,運(yùn)行結(jié)果是99
//以C++的方式編譯,運(yùn)行結(jié)果是10
//在C語(yǔ)言中,輸出n時(shí)會(huì)到內(nèi)存中獲取n的值,這個(gè)時(shí)候n所在的內(nèi)存中的數(shù)據(jù)已經(jīng)被修改成了99
//在C++中,print("%d\n", n);語(yǔ)句在編譯時(shí)就將n的值替換成了10,不管n所在內(nèi)存如何變化,都不影響輸出結(jié)果。
C++中全局const變量的可見(jiàn)范圍是當(dāng)前文件
普通全局變量的作用域是當(dāng)前文件,但是在其他文件中也是可見(jiàn)的,使用extern聲明后就可以使用。
/*源文件1*/
#include <stdio.h>
#include"func.cpp"
int n = 10;
void func();
int main(){
func();
printf("main: %d\n", n);
return 0;
}
/*源文件2*/
#include <stdio.h>
extern int;
void func();
{
printf("module: %d\n", n);
}
/*運(yùn)行結(jié)果:*/ module:10 main:10 //在C語(yǔ)言中,const變量和普通變量一樣,在其他源文件中也是可見(jiàn)的。 const int n = 10; //在C語(yǔ)言中的const變量在多文件編譯時(shí)的表現(xiàn)和普通變量一樣,除了不能修改,沒(méi)有其他區(qū)別。 //在C++中,修改后的代碼是錯(cuò)誤的。
C++規(guī)定全局const變量的可見(jiàn)范圍僅限于當(dāng)前源文件,所以可以將它放在頭文件中,這樣即使頭文件被包含多次也不會(huì)出錯(cuò)。
總結(jié):
C++中的const變量雖然也會(huì)占用內(nèi)存,也能使用&獲取它的地址,但是使用時(shí)卻更像編譯時(shí)期的#define;
#define也是值替換,可見(jiàn)范圍也是當(dāng)前文件;
#define定義的常量?jī)H僅是字符串的替換,不會(huì)進(jìn)行類型檢查,
而const定義的常量是有類型的,編譯器會(huì)進(jìn)行類型檢查。
知識(shí)點(diǎn)補(bǔ)充:
const修飾函數(shù)參數(shù)
const修飾參數(shù)是為了防止函數(shù)體內(nèi)可能會(huì)修改參數(shù)原始對(duì)象。因此,有三種情況可討論:
- 函數(shù)參數(shù)為值傳遞:值傳遞(pass-by-value)是傳遞一份參數(shù)的拷貝給函數(shù),因此不論函數(shù)體代碼如何運(yùn)行,也只會(huì)修改拷貝而無(wú)法修改原始對(duì)象,這種情況不需要將參數(shù)聲明為const。
- 函數(shù)參數(shù)為指針:指針傳遞(pass-by-pointer)只會(huì)進(jìn)行淺拷貝,拷貝一份指針給函數(shù),而不會(huì)拷貝一份原始對(duì)象。因此,給指針參數(shù)加上頂層const可以防止指針指向被篡改,加上底層const可以防止指向?qū)ο蟊淮鄹摹?/li>
- 函數(shù)參數(shù)為引用:引用傳遞(pass-by-reference)有一個(gè)很重要的作用,由于引用就是對(duì)象的一個(gè)別名,因此不需要拷貝對(duì)象,減小了開(kāi)銷。這同時(shí)也導(dǎo)致可以通過(guò)修改引用直接修改原始對(duì)象(畢竟引用和原始對(duì)象其實(shí)是同一個(gè)東西),因此,大多數(shù)時(shí)候,推薦函數(shù)參數(shù)設(shè)置為pass-by-reference-to-const。給引用加上底層const,既可以減小拷貝開(kāi)銷,又可以防止修改底層所引用的對(duì)象。
以上就是C++ const關(guān)鍵字的實(shí)例用法的詳細(xì)內(nèi)容,更多關(guān)于C++ const關(guān)鍵字請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
C 語(yǔ)言編寫(xiě)一個(gè)計(jì)算器界面(可視化界面和多功能)
今天給大家分享一個(gè)計(jì)算器功能,主要功能有加法減法乘除法求余功能,用戶可以在主菜單選擇需要計(jì)算的功能,接下來(lái)根據(jù)用戶輸入的數(shù)字進(jìn)行計(jì)算輸出結(jié)果,喜歡的朋友拿去用吧2021-06-06
C++中靜態(tài)成員函數(shù)訪問(wèn)非靜態(tài)成員的實(shí)例
這篇文章主要介紹了C++中靜態(tài)成員函數(shù)訪問(wèn)非靜態(tài)成員的實(shí)例的相關(guān)資料,需要的朋友可以參考下2017-07-07
Linux下C語(yǔ)言的幾道經(jīng)典面試題小結(jié)(分享)
下面小編就為大家?guī)?lái)一篇Linux下C語(yǔ)言的幾道經(jīng)典面試題小結(jié)(分享)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-05-05
C++實(shí)現(xiàn)地鐵自動(dòng)售票系統(tǒng)程序設(shè)計(jì)
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)地鐵自動(dòng)售票系統(tǒng)程序設(shè)計(jì),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03
C++實(shí)現(xiàn)LeetCode(123.買股票的最佳時(shí)間之三)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(123.買股票的最佳時(shí)間之三),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07
Java?C++?算法題解leetcode652尋找重復(fù)子樹(shù)
這篇文章主要為大家介紹了Java?C++?算法題解leetcode652尋找重復(fù)子樹(shù)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09
在C++程序中開(kāi)啟和禁用Windows設(shè)備的無(wú)線網(wǎng)卡的方法
這篇文章主要介紹了在C++程序中開(kāi)啟和禁用Windows設(shè)備的無(wú)線網(wǎng)卡的方法,包括一些常見(jiàn)錯(cuò)誤的分析與解決,需要的朋友可以參考下2016-03-03
C++高精度計(jì)時(shí)的幾種方法總結(jié)(測(cè)試函數(shù)運(yùn)行時(shí)間)
本文介紹了C++中常用的幾種程序計(jì)時(shí)方法,包括clock()函數(shù)、GetTickCount()、QueryPerformanceCounter()以及C++11中的chrono庫(kù)函數(shù),這篇文章主要介紹了C++高精度計(jì)時(shí)的幾種方法,需要的朋友可以參考下2024-09-09

