C++中const的實現(xiàn)機制深入分析
更新時間:2012年12月02日 15:52:52 作者:
C語言以及C++語言中的const究竟表示什么?其具體的實現(xiàn)機制又是如何實現(xiàn)的呢?本文將對這兩個問題進行一些分析,需要了解的朋友可以參考下
問題
C語言以及C++語言中的const究竟表示什么?其具體的實現(xiàn)機制又是如何實現(xiàn)的呢? 本文將對這兩個問題進行一些分析,簡單解釋const的含義以及實現(xiàn)機制。
問題分析
簡單的說const在C語言中表示只讀的變量,而在C++語言中表示常量。關(guān)于const在C與C++語言中的使用以及更多的區(qū)別,以后有時間另開一貼說明。
那么const究竟是如何實現(xiàn)的呢? 對于聲明為const的內(nèi)置類型,例如int,short,long等等,編譯器會如何實現(xiàn)const的本意?那么對于非內(nèi)置類型是否也是與內(nèi)置數(shù)據(jù)類型一樣處理呢,例如對于結(jié)構(gòu)體類型則會怎樣處理呢?下面通過幾個小例子來說明這些問題:
C語言const示例:
const int i=10;
int *p=(int *)(&i);
*p=20;
printf("i=%d *p=%d \n",i,*p);
猜一猜輸出結(jié)果是什么? i=20 *p=20
C++語言const示例1:
const int i=10;
int *p=const_cast<int *>(&i);
*p=20;
cout<<"i="<<i<<" *p="<<*p<<endl;
輸出結(jié)果是 i=10 *p=20
C++語言const示例2:
struct test{
int j;
char tmp;
test()
{
j=30;
tmp='a';
}
};
int main(int argc, char* argv[])
{
const struct test t1;
int *q=(int *)(&t1.j);
*q=40;
cout<<"j="<<t1.j<<" *q="<<*q<<endl;
return 0;
}
輸出結(jié)果是 j=40 *q=40
示例結(jié)果分析
看到上面三組輸出結(jié)果,有沒有感到很詭異:
問題1,對于const int類型的變量i,C語言中通過指針p修改了值后,i變成了20;而在C++中,通過指針p修改了值后,i仍然是10。
問題2,C++語言中 const struct test的元素j通過指針q被改變了,為何const int 與 const struct test的反應(yīng)機制不同?
針對問題1,我們知道C語言中const表示只讀的變量,既然把const看成是變量,那么其在內(nèi)存中就會有存儲他的空間,并且可以通過指針間接的改變該內(nèi)存空間的值,當(dāng)通過指針p改變該內(nèi)存中的值后,再獲取i的值的時候,會訪問該空間,得到的是被改變后的值。而C++把const看做常量,編譯器會使用常數(shù)直接替換掉對i的引用,例如cout<<i; 會理解成cout<<10; 并不會去訪問i的內(nèi)存地址去取數(shù)據(jù),這里有點像是C語言里的宏#define i 10。因此C++里i會輸出10,而*p會輸出20.
針對問題2,C++語言中只是對于內(nèi)置數(shù)據(jù)類型做常數(shù)替換,而對于像結(jié)構(gòu)體這樣的非內(nèi)置數(shù)據(jù)類型則不會。因為結(jié)構(gòu)體類型不是內(nèi)置數(shù)據(jù)類型,編譯器不知道如何直接替換,因此必須要訪問內(nèi)存去取數(shù)據(jù),而訪問內(nèi)存去取數(shù)據(jù)必然會取到被指針q改變后的值,因此會造成與C++中const int類型完全不一樣的處理模式。
小結(jié)
C語言與C++有很多的區(qū)別與聯(lián)系,const只是其中一個方面,對于const的理解和使用是編程的基礎(chǔ),需要熟練掌握。
C語言以及C++語言中的const究竟表示什么?其具體的實現(xiàn)機制又是如何實現(xiàn)的呢? 本文將對這兩個問題進行一些分析,簡單解釋const的含義以及實現(xiàn)機制。
問題分析
簡單的說const在C語言中表示只讀的變量,而在C++語言中表示常量。關(guān)于const在C與C++語言中的使用以及更多的區(qū)別,以后有時間另開一貼說明。
那么const究竟是如何實現(xiàn)的呢? 對于聲明為const的內(nèi)置類型,例如int,short,long等等,編譯器會如何實現(xiàn)const的本意?那么對于非內(nèi)置類型是否也是與內(nèi)置數(shù)據(jù)類型一樣處理呢,例如對于結(jié)構(gòu)體類型則會怎樣處理呢?下面通過幾個小例子來說明這些問題:
C語言const示例:
復(fù)制代碼 代碼如下:
const int i=10;
int *p=(int *)(&i);
*p=20;
printf("i=%d *p=%d \n",i,*p);
猜一猜輸出結(jié)果是什么? i=20 *p=20
C++語言const示例1:
復(fù)制代碼 代碼如下:
const int i=10;
int *p=const_cast<int *>(&i);
*p=20;
cout<<"i="<<i<<" *p="<<*p<<endl;
輸出結(jié)果是 i=10 *p=20
C++語言const示例2:
復(fù)制代碼 代碼如下:
struct test{
int j;
char tmp;
test()
{
j=30;
tmp='a';
}
};
int main(int argc, char* argv[])
{
const struct test t1;
int *q=(int *)(&t1.j);
*q=40;
cout<<"j="<<t1.j<<" *q="<<*q<<endl;
return 0;
}
輸出結(jié)果是 j=40 *q=40
示例結(jié)果分析
看到上面三組輸出結(jié)果,有沒有感到很詭異:
問題1,對于const int類型的變量i,C語言中通過指針p修改了值后,i變成了20;而在C++中,通過指針p修改了值后,i仍然是10。
問題2,C++語言中 const struct test的元素j通過指針q被改變了,為何const int 與 const struct test的反應(yīng)機制不同?
針對問題1,我們知道C語言中const表示只讀的變量,既然把const看成是變量,那么其在內(nèi)存中就會有存儲他的空間,并且可以通過指針間接的改變該內(nèi)存空間的值,當(dāng)通過指針p改變該內(nèi)存中的值后,再獲取i的值的時候,會訪問該空間,得到的是被改變后的值。而C++把const看做常量,編譯器會使用常數(shù)直接替換掉對i的引用,例如cout<<i; 會理解成cout<<10; 并不會去訪問i的內(nèi)存地址去取數(shù)據(jù),這里有點像是C語言里的宏#define i 10。因此C++里i會輸出10,而*p會輸出20.
針對問題2,C++語言中只是對于內(nèi)置數(shù)據(jù)類型做常數(shù)替換,而對于像結(jié)構(gòu)體這樣的非內(nèi)置數(shù)據(jù)類型則不會。因為結(jié)構(gòu)體類型不是內(nèi)置數(shù)據(jù)類型,編譯器不知道如何直接替換,因此必須要訪問內(nèi)存去取數(shù)據(jù),而訪問內(nèi)存去取數(shù)據(jù)必然會取到被指針q改變后的值,因此會造成與C++中const int類型完全不一樣的處理模式。
小結(jié)
C語言與C++有很多的區(qū)別與聯(lián)系,const只是其中一個方面,對于const的理解和使用是編程的基礎(chǔ),需要熟練掌握。
相關(guān)文章
C++?protobuf中對不同消息內(nèi)容進行賦值的方式總結(jié)(set_、set_allocated_、mutable_、
這篇文章主要給大家介紹了關(guān)于C++?protobuf中對不同消息內(nèi)容進行賦值的方式總結(jié),主要使用的是set_、set_allocated_、mutable_、add_,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-03-03C++輸出上三角/下三角/菱形/楊輝三角形(實現(xiàn)代碼)
本篇文章是對C++中輸出上三角/下三角/菱形/楊輝三角形的示例代碼進行了詳細(xì)的分析介紹,需要的朋友參考下2013-07-07