C++編譯器如何對Const常量進(jìn)行分配存儲空間
所謂C++編譯器,C++編譯器是C++中的一個與標(biāo)準(zhǔn)化高度兼容的編譯環(huán)境,編譯器對不同的CPU會進(jìn)行不同的優(yōu)化,下面說明C++編譯器進(jìn)行Const常量分配存儲空間的說明介紹。
Const 是C++中常用的類型修飾符,有某些微妙的應(yīng)用場合,如果沒有搞清本源,則錯誤在所難免。本篇中將對const進(jìn)行辨析。溯其本源,究其實質(zhì),希望能對大家理解const有所幫助,根據(jù)思維的承接關(guān)系,分為如下幾個部分進(jìn)行闡述。C++的提出者當(dāng)初是基于什么樣的目的引入(或者說保留)const關(guān)鍵字呢?,這是一個有趣又有益的話題,對理解const很有幫助。
1. 大家知道,C++有一個類型嚴(yán)格的編譯系統(tǒng),這使得C++程序的錯誤在編譯階段即可發(fā)現(xiàn)許多,從而使得出錯率大為減少,因此,也成為了C++與C相比,有著突出優(yōu)點的一個方面。
2. C++中很常見的預(yù)處理指令 #define VariableName VariableValue 可以很方便地進(jìn)行值替代,這種值替代至少在三個方面優(yōu)點突出:一是避免了意義模糊的數(shù)字出現(xiàn),使得程序語義流暢清晰。
二是可以很方便地進(jìn)行參數(shù)的調(diào)整與修改,如上例,當(dāng)人數(shù)由107變?yōu)?01時,進(jìn)改動此處即可,三是提高了程序的執(zhí)行效率,由于使用了預(yù)編譯器進(jìn)行值替代,并不需要為這些常量分配存儲空間,所以執(zhí)行的效率較高。鑒于以上的優(yōu)點,這種預(yù)定義指令的使用在程序中隨處可見。
3. 說到這里,大家可能會迷惑上述的1點、2點與const有什么關(guān)系呢?,好,請接著向下看來:
預(yù)處理語句雖然有以上的許多優(yōu)點,但它有個比較致命的缺點,即,預(yù)處理語句僅僅只是簡單值替代,缺乏類型的檢測機制。這樣預(yù)處理語句就不能享受C++嚴(yán)格類型檢查的好處,從而可能成為引發(fā)一系列錯誤的隱患。
4.好了,第一階段結(jié)論出來了:
結(jié)論: Const 推出的初始目的,正是為了取代預(yù)編譯指令,消除它的缺點,同時繼承它的優(yōu)點。
現(xiàn)在它的形式變成了:
Const DataType VariableName = VariableValue ;為什么const能很好地取代預(yù)定義語句?const 到底有什么大神通,使它可以振臂一揮取代預(yù)定義語句呢?
1. 首先,以const 修飾的常量值,具有不可變性,這是它能取代預(yù)定義語句的基礎(chǔ)。
2. 第二,很明顯,它也同樣可以避免意義模糊的數(shù)字出現(xiàn),同樣可以很方便地進(jìn)行參數(shù)的調(diào)整和修改。
3. 第三,C++的編譯器通常不為普通const常量分配存儲空間,而是將它們保存在符號表中,這使得它成為一個編譯期間的常量,沒有了存儲與讀內(nèi)存的操作,使得它的效率也很高,同時,這也是它取代預(yù)定義語句的重要基礎(chǔ)。
這里,我要提一下,為什么說這一點是也是它能取代預(yù)定義語句的基礎(chǔ),這是因為,編譯器不會去讀存儲的內(nèi)容,如果編譯器為const分配了存儲空間,它就不能夠成為一個編譯期間的常量了。
4. 最后,const定義也像一個普通的變量定義一樣,它會由編譯器對它進(jìn)行類型的檢測,消除了預(yù)定義語句的隱患。
分析:上述寫法限定函數(shù)的返回值不可被更新,當(dāng)函數(shù)返回內(nèi)部的類型時(如fun1),已經(jīng)是一個數(shù)值,當(dāng)然不可被賦值更新。所以,此時const無意義,最好去掉,以免困惑。當(dāng)函數(shù)返回自定義的類型時(如fun2),這個類型仍然包含可以被賦值的變量成員,所以,此時有意義。
【編輯推薦】