C++中const的實(shí)現(xiàn)機(jī)制深入分析
更新時(shí)間:2012年12月02日 15:52:52 作者:
C語言以及C++語言中的const究竟表示什么?其具體的實(shí)現(xiàn)機(jī)制又是如何實(shí)現(xiàn)的呢?本文將對(duì)這兩個(gè)問題進(jìn)行一些分析,需要了解的朋友可以參考下
問題
C語言以及C++語言中的const究竟表示什么?其具體的實(shí)現(xiàn)機(jī)制又是如何實(shí)現(xiàn)的呢? 本文將對(duì)這兩個(gè)問題進(jìn)行一些分析,簡(jiǎn)單解釋const的含義以及實(shí)現(xiàn)機(jī)制。
問題分析
簡(jiǎn)單的說const在C語言中表示只讀的變量,而在C++語言中表示常量。關(guān)于const在C與C++語言中的使用以及更多的區(qū)別,以后有時(shí)間另開一貼說明。
那么const究竟是如何實(shí)現(xiàn)的呢? 對(duì)于聲明為const的內(nèi)置類型,例如int,short,long等等,編譯器會(huì)如何實(shí)現(xiàn)const的本意?那么對(duì)于非內(nèi)置類型是否也是與內(nèi)置數(shù)據(jù)類型一樣處理呢,例如對(duì)于結(jié)構(gòu)體類型則會(huì)怎樣處理呢?下面通過幾個(gè)小例子來說明這些問題:
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,對(duì)于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)機(jī)制不同?
針對(duì)問題1,我們知道C語言中const表示只讀的變量,既然把const看成是變量,那么其在內(nèi)存中就會(huì)有存儲(chǔ)他的空間,并且可以通過指針間接的改變?cè)搩?nèi)存空間的值,當(dāng)通過指針p改變?cè)搩?nèi)存中的值后,再獲取i的值的時(shí)候,會(huì)訪問該空間,得到的是被改變后的值。而C++把const看做常量,編譯器會(huì)使用常數(shù)直接替換掉對(duì)i的引用,例如cout<<i; 會(huì)理解成cout<<10; 并不會(huì)去訪問i的內(nèi)存地址去取數(shù)據(jù),這里有點(diǎn)像是C語言里的宏#define i 10。因此C++里i會(huì)輸出10,而*p會(huì)輸出20.
針對(duì)問題2,C++語言中只是對(duì)于內(nèi)置數(shù)據(jù)類型做常數(shù)替換,而對(duì)于像結(jié)構(gòu)體這樣的非內(nèi)置數(shù)據(jù)類型則不會(huì)。因?yàn)榻Y(jié)構(gòu)體類型不是內(nèi)置數(shù)據(jù)類型,編譯器不知道如何直接替換,因此必須要訪問內(nèi)存去取數(shù)據(jù),而訪問內(nèi)存去取數(shù)據(jù)必然會(huì)取到被指針q改變后的值,因此會(huì)造成與C++中const int類型完全不一樣的處理模式。
小結(jié)
C語言與C++有很多的區(qū)別與聯(lián)系,const只是其中一個(gè)方面,對(duì)于const的理解和使用是編程的基礎(chǔ),需要熟練掌握。
C語言以及C++語言中的const究竟表示什么?其具體的實(shí)現(xiàn)機(jī)制又是如何實(shí)現(xiàn)的呢? 本文將對(duì)這兩個(gè)問題進(jìn)行一些分析,簡(jiǎn)單解釋const的含義以及實(shí)現(xiàn)機(jī)制。
問題分析
簡(jiǎn)單的說const在C語言中表示只讀的變量,而在C++語言中表示常量。關(guān)于const在C與C++語言中的使用以及更多的區(qū)別,以后有時(shí)間另開一貼說明。
那么const究竟是如何實(shí)現(xiàn)的呢? 對(duì)于聲明為const的內(nèi)置類型,例如int,short,long等等,編譯器會(huì)如何實(shí)現(xiàn)const的本意?那么對(duì)于非內(nèi)置類型是否也是與內(nèi)置數(shù)據(jù)類型一樣處理呢,例如對(duì)于結(jié)構(gòu)體類型則會(huì)怎樣處理呢?下面通過幾個(gè)小例子來說明這些問題:
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,對(duì)于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)機(jī)制不同?
針對(duì)問題1,我們知道C語言中const表示只讀的變量,既然把const看成是變量,那么其在內(nèi)存中就會(huì)有存儲(chǔ)他的空間,并且可以通過指針間接的改變?cè)搩?nèi)存空間的值,當(dāng)通過指針p改變?cè)搩?nèi)存中的值后,再獲取i的值的時(shí)候,會(huì)訪問該空間,得到的是被改變后的值。而C++把const看做常量,編譯器會(huì)使用常數(shù)直接替換掉對(duì)i的引用,例如cout<<i; 會(huì)理解成cout<<10; 并不會(huì)去訪問i的內(nèi)存地址去取數(shù)據(jù),這里有點(diǎn)像是C語言里的宏#define i 10。因此C++里i會(huì)輸出10,而*p會(huì)輸出20.
針對(duì)問題2,C++語言中只是對(duì)于內(nèi)置數(shù)據(jù)類型做常數(shù)替換,而對(duì)于像結(jié)構(gòu)體這樣的非內(nèi)置數(shù)據(jù)類型則不會(huì)。因?yàn)榻Y(jié)構(gòu)體類型不是內(nèi)置數(shù)據(jù)類型,編譯器不知道如何直接替換,因此必須要訪問內(nèi)存去取數(shù)據(jù),而訪問內(nèi)存去取數(shù)據(jù)必然會(huì)取到被指針q改變后的值,因此會(huì)造成與C++中const int類型完全不一樣的處理模式。
小結(jié)
C語言與C++有很多的區(qū)別與聯(lián)系,const只是其中一個(gè)方面,對(duì)于const的理解和使用是編程的基礎(chǔ),需要熟練掌握。
相關(guān)文章
C++?protobuf中對(duì)不同消息內(nèi)容進(jìn)行賦值的方式總結(jié)(set_、set_allocated_、mutable_、
這篇文章主要給大家介紹了關(guān)于C++?protobuf中對(duì)不同消息內(nèi)容進(jìn)行賦值的方式總結(jié),主要使用的是set_、set_allocated_、mutable_、add_,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-03-03C++輸出上三角/下三角/菱形/楊輝三角形(實(shí)現(xiàn)代碼)
本篇文章是對(duì)C++中輸出上三角/下三角/菱形/楊輝三角形的示例代碼進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-07-07C語言實(shí)現(xiàn)簡(jiǎn)單的定時(shí)器
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)簡(jiǎn)單的定時(shí)器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-10-10C語言從基礎(chǔ)到進(jìn)階全面講解數(shù)組
數(shù)組是一組有序的數(shù)據(jù)的集合,數(shù)組中元素類型相同,由數(shù)組名和下標(biāo)唯一地確定,數(shù)組中數(shù)據(jù)不僅數(shù)據(jù)類型相同,而且在計(jì)算機(jī)內(nèi)存里連續(xù)存放,地址編號(hào)最低的存儲(chǔ)單元存放數(shù)組的起始元素,地址編號(hào)最高的存儲(chǔ)單元存放數(shù)組的最后一個(gè)元素2022-05-05C++?ncnn模型驗(yàn)證精度實(shí)現(xiàn)代碼
這篇文章主要介紹了C++?ncnn模型驗(yàn)證精度實(shí)現(xiàn)過程,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2023-02-02