日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

【小知识】C、C++ 中const的实现机制

發布時間:2025/7/14 58 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【小知识】C、C++ 中const的实现机制 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

之前對于const的理解,可以說是知道“然”,但不知道“所以然”,意思是我知道被const修飾的標識符是一個“常量”,但是不知道為什么是這樣,還有C和C++中const的實現機制有何區別。下面就來學習下這個小知識。

一句話概括就是:const在C語言中表示只讀的變量,而在C++中表示一個常量。

C語言中,const表示只讀的變量,存儲在內存中,可以通過指針改變該存儲空間中的值。

看以下例子:

1 const int var = 10; 2 int *ptr = (int *)(&var); 3 *ptr = 20; 4 printf("var=%d *ptr=%d \n",var,*ptr);

輸出結果是:var=20 *ptr=20 。這是因為指針ptr改變了內存中的值。當程序讀取var數據時,得到的是被修改后的值。

C++語言中,const被看做常量,編譯器使用常數直接替換掉被const修飾的標識符的引用,并不會通過訪問內存去讀取數據,這一點類似C語言中的宏#define。

看以下例子:

1 const int var = 10; 2 int *ptr = const_cast<int *>(&var); 3 *ptr = 20; 4 cout<<"var="<<var<<" *ptr="<<*ptr<<endl;

輸出結果是:var=10 *ptr=20。這是因為編譯器使用常量直接替換掉了對var的的引用,而不是從內存中讀取var值。

此外,C++語言中,只是對于內置數據類型做常數替換,而對于像結構體這樣的非內置數據類型則不會。因為結構體類型不是內置數據類型,編譯器不知道如何直接替換,因此必須要訪問內存去取數據,而訪問內存去取數據必然會取到被指針q改變后的值,因此會造成與C++中const內置類型完全不一樣的處理模式。

看以下例子:

1 struct test 2 { 3 int var; 4 test() 5 { 6 var = 30; 7 } 8 }; 9 10 int main() 11 { 12 const test testobj; 13 int *ptr = (int *)(&testobj.var); 14 *ptr = 40; 15 cout<<"var="<<testobj.var<<" *ptr="<<*ptr<<endl; 16 return 0; 17 }

輸出結果是:

var=40 *ptr=40。這是因為對于非內置數據類型,編譯器不知道如何直接替換,所以對于var取值仍是通過讀取它的存儲空間中的值來獲得。

總結一下,就是:const在C語言中表示只讀的變量,而在C++中對于內置類型表示一個常量,對于非內置類型表示只讀的變量。

轉載于:https://www.cnblogs.com/xiaogege/archive/2013/04/11/const_c_cpp.html

總結

以上是生活随笔為你收集整理的【小知识】C、C++ 中const的实现机制的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。