听说爱情回来过

导航

【小知识】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++中对于内置类型表示一个常量,对于非内置类型表示只读的变量。

posted on 2013-04-11 19:38  听说爱情回来过  阅读(1821)  评论(0编辑  收藏  举报