#includeint main( void ) { const int a = 10; a = 20; }12345671234567
結(jié)果怎樣?
創(chuàng)新互聯(lián)專注骨干網(wǎng)絡(luò)服務(wù)器租用十年,服務(wù)更有保障!服務(wù)器租用,中國電信云錦天府 成都服務(wù)器租用,成都服務(wù)器托管,骨干網(wǎng)絡(luò)帶寬,享受低延遲,高速訪問。靈活、實現(xiàn)低成本的共享或公網(wǎng)數(shù)據(jù)中心高速帶寬的專屬高性能服務(wù)器。
編譯錯誤
[Error] assignment of read-only variable ‘a(chǎn)’ 變量a是只讀的。
得到一個結(jié)論,使用const修飾的變量是常量,我們無法修改。在gcc中把const常量放到了data段,和全局變量一樣,只是把它放到了一個區(qū)域中讓我們無法修改,在運行過程中并沒有標記const。
了解內(nèi)容:
三種內(nèi)存來源: 棧(stack) 堆(heap) 數(shù)據(jù)區(qū)(data)(也就是數(shù)據(jù)段)
(1)在操作系統(tǒng)專用獲取內(nèi)存的三種方式(C語言程序中): 棧(stack) 堆(heap) 數(shù)據(jù)區(qū)(data)(也就是數(shù)據(jù)段)
難道const定義的變量真的不能被修改嗎?
#includeint main( void ) { const int a = 10; int * p = &a; *p = 20; printf(" a = %d\n ",a); }//編譯信息:[Warning] initialization discards 'const' qualifier from pointer target type [enabled by default]1234567891012345678910
變量a居然被修改了。。。好神奇。再來深入理解const含義,const定義的變量真的是不能被修改嗎?不是的。有時候我們在傳輸數(shù)據(jù)的時候,只希望從我家血池傳送到地方水晶去,在中途不被干擾,就讓const來保駕護航,保護變量a的安全。但是若有一個更強大的英雄(指針)來刺殺變量a,也是有可能的,不僅無視const守衛(wèi),還干掉了變量a。
使用const關(guān)鍵字主要是告訴程序員和編譯器,這個變量不必要修改,我們的目的是使用它,不是改變它(若要惡意修改也是可以做到的)
注意:
第一次直接給const常量賦值的編譯信息是error,第二次通過指針給const常量賦值的編譯信息是warning,這也證明了,const常量可以修改,但是一定要注意自己在干什么,也就是說程序員一定要知道自己已經(jīng)修改了const常量。
const 修飾指針有4中形式,區(qū)分這四種即可理解const和指針。
第一種:const int*p // 指針所指向的變量是常量
第二種:int const *p //指針所指向的變量是常量
第三種:int* const p // 指針p本身是常量
第四種:const int * const p //指針p本身和他所指向的變量都是常量
有點亂哈,記住這句話就好多了
注意區(qū)分指針變量本身和指針所指向的變量。一個const只能修飾一個變量。
>第一種:const int * p // 指針所指向的變量是常量 int a = 10; int b = 20; const int * p =&a; //*p = 30; //const修飾的是指針所指向的變量,所以這行出錯 p = &b; //指針變量本身是可以修改的>第二種:int const *p //指針所指向的變量是常量 int a = 10; int b = 20; const int * p =&a; //*p = 30; //const修飾的是指針所指向的變量,所以這行出錯 p = &b; //指針變量本身是可以修改的上面兩種情況都是指針指向的變量是常量不可修改,下面來看指針本身是不可修改的。 >第三種:int* const p // 指針p本身是常量 int a = 10; int b = 20; int * const p = &a; //指針指向a *p = 30; //指針指向的變量是可以修改的 //p = &b; //指針p本身是不可修改的>第四種:const int * const p //指針p本身和他所指向的變量都是常量 int a = 10; int b = 20; const int *const p = &a; //指針本身和指針指向的變量都是不可修改的 //*p = 30; 出錯 //p = &b; 出錯12345678910111213141516171819202122232425262728291234567891011121314151617181920212223242526272829
怎么區(qū)分誰是不可修改的?
分析:
// 第一種:const int*p // 第二種:int const *p // 第三種:int* const p // 第四種:const int * const p 12341234
第一種情況:const int*p
const 后面是int*p; int*p是一個整體,是指針指向的變量,所以const 修飾指針指向的變量
第二種:int const *p
const 后面是 *p; *p是指針指向的變量,所以const修飾指針指向的變量
第三種:int* const p
const 后面是 p,p是指針,所以const修飾的是指針本身,而不是它所指向的變量
第四種:const int * const p
先看第二個const得知修飾的是指針,再來看第一個const,和第一種一樣了,修飾的指針指向的變量。
學(xué)會一步一步的分析,從關(guān)鍵字出發(fā),一步一步來。
const 修飾的變量可以通過指針來修改
const int a = 10;int * p = &a;*p = 20;printf(" a = %d\n",a);12341234
const修飾的指針如何修改?int a = 1;int b = 2;int * const p = &a;//p = &b; //直接修改肯定會出錯,那怎么辦?//修改const變量是通過指針,那再通過指針修改指針行不行呢?int a = 1;int b = 2;int **test;int * const p = &a; test = &p; *test = &b; printf("*p = %d\n",*p); ////*p = 0000000000000002 //指針從原來的指向a,變成了現(xiàn)在指向的b123456789101112131415123456789101112131415
總結(jié):
這里用到了二級指針,了解為主,后面我們會深入研究的。這節(jié)課的重點是搞清const 與指針的用法,能夠區(qū)分const修飾的是誰就可以了