十年網(wǎng)站開發(fā)經(jīng)驗 + 多家企業(yè)客戶 + 靠譜的建站團(tuán)隊
量身定制 + 運營維護(hù)+專業(yè)推廣+無憂售后,網(wǎng)站問題一站解決
對于const變量,人們有個誤區(qū),就是認(rèn)為const是個常量,其實這種說法是不正確的,const本質(zhì)還是一個變量,只是這個變量被const修飾后成為了只讀的變量。
成都創(chuàng)新互聯(lián)是工信部頒發(fā)資質(zhì)IDC服務(wù)器商,為用戶提供優(yōu)質(zhì)的川西大數(shù)據(jù)中心服務(wù)
const只讀變量
關(guān)于const有幾點要注意的:
1.const修飾的變量是只讀的,本質(zhì)還是變量。
2.const修飾的局部變量在棧上分配空間。
3.const修飾的全局變量在全局?jǐn)?shù)據(jù)區(qū)分配空間。
4.const只在編譯期有用,在運行期無用。
const修飾的變量不是真正的常量,它只是告訴編譯器該變量不能出現(xiàn)在賦值符號的左邊。
const全局變量的分歧
在現(xiàn)代C語言編譯器中,修改const全局變量將導(dǎo)致程序崩潰(在現(xiàn)代C語言編譯器中,被const修飾的全局變量被編譯器存放在只讀存儲區(qū),所以修改該變量將導(dǎo)致程序奔潰)
注意:標(biāo)準(zhǔn)C語言編譯器不會將const修飾的全局變量存儲于只讀存儲區(qū)中,而是存儲于可修改的全局?jǐn)?shù)據(jù)區(qū),其值依然可以改變。
下面我們通過一個編程實驗來驗證一下。
這是在BCC編譯環(huán)境下的運行結(jié)果,BCC是一款標(biāo)準(zhǔn)C語言編譯器,它將const修飾的全局變量存儲于可以改變的全局?jǐn)?shù)據(jù)區(qū)。所以當(dāng)程序改變其中的變量的時候,不會報錯。
在linux系統(tǒng)中運行程序會出現(xiàn)段錯誤的提示,原因是因為gcc編譯器是一款現(xiàn)代C語言編譯器,全局變量i被const修飾后,被編譯器存儲在只讀存儲區(qū),當(dāng)視圖修改的時候會報錯。
在函數(shù)中,局部變量i被static修飾后,成為全局變量,當(dāng)用const修飾后,編譯器將它儲存在只讀存儲區(qū)。再次修改會出錯。
在linux中 局部變量i被const修飾后,gcc編譯器將它存儲在棧上,其值可以改變。程序不報錯。
const的本質(zhì)
1.C語言中的const使得變量具有只讀屬性。
2.現(xiàn)代C編譯器中的const將具有全局生命周期的變量存儲于只讀存儲區(qū)。
3.const本能定義真正意義上的常量。
const修飾函數(shù)參數(shù)和返回值
1.const修飾函數(shù)的參數(shù)表示在函數(shù)體內(nèi)不希望改變參數(shù)的值。
2.const修飾函數(shù)返回值表示返回值不可以改變,多用于返回指針的情形。
Tips:
C語言中的字符串字面量存儲于只讀存儲區(qū),在程序中需要使用const char* 指針。
程序中有兩處錯誤,第一處是j變量被static const修飾后 編譯器將它存儲在只讀存儲區(qū),修改值會出現(xiàn)程序奔潰,第二處是全局變量g_array被const修飾也被編譯器存儲在只讀存儲區(qū),修改值會發(fā)生程序奔潰。
深藏不露的volatile
1.volatile可以理解為編譯器警告指示字;
2.volatile告訴編譯器必須每次去內(nèi)存中去變量值。
3.volatile主要修飾可能被多個線程訪問的變量。
4.volatile也可以修飾可能被多個未知因數(shù)改變的變量。
一個有趣的問題
const volatile int i=0;
-變量i具有什么樣的特性?
-編譯器如何處理這個變量?
i是一個只讀變量,編譯器不做任何優(yōu)化,每次訪問i的時候 都會讓編譯器去內(nèi)存中去取值。
小結(jié)
const使得變量具有只讀屬性
const不能定義真正意義上的常量。
const將具有全局生命期的變量存儲于只讀存儲區(qū)
volatile強(qiáng)制編譯器減少優(yōu)化,必須每次從內(nèi)存中取值。