C与C++中的const

同样,有下面一段代码:

 1 #include <iostream>
 2 using namespace std;
 3 
 4 int main()
 5 {
 6     const int i = 0; 
 7     int *j = (int *) &i; 
 8     *j = 1; 
 9     cout<<"i address = 0x"<<hex<<&i<<","<<"j address = 0x"<<hex<<j<<endl;
10     cout<<"i value = "<<i<<","<<"j value = "<<*j<<endl;
11     system("pause");
12     return 0;
13 }

我们在C++编译器中运行如下:

我们发现const关键字严格遵守了其关于常量的定义。然而疑问出来了

为什么相同的地址会输出不同的值。

同样的代码我们放入C编译器中运行会发现输出结果:

i value = 1,j value =1

这是为什么呢?

以下是我自己的一点理解:

1.C语言中const为不可改变的变量,其实质仍然是变量,仍然会在编译期间分配内存

   那么我们可以获取该内存并修改该内存处的值。这样虽然不允许直接对const 变量修改

   但是间接修改该内存位置的值达到修改该变量的效果。

2.C++中const关键字定义的是常量类型,在编译的期间直接确定了其值,比如我们

   可进行如下操作在C++中 编译是可以通过的

1 const int size=5;
2 int array[size];

    表明在编译的时候size是已经确定了。然而这种情况在C语言的情况下是绝对不可以编译通过的,

    其实我猜,当我们在c++中定义一个const类型的变量的时候,编译器也是要为其分配内存的,

    只不过在编译阶段遇到时候直接替换,在运行的时候,该常量的值是直接存在某个寄存器中,这样

    运行代码中需要用到该值时直接可从寄存器中索取,而非在内存中索取。

那么,我们可以作这样一种测试,我们把const前面加上volatile关键字防止编译器直接从寄存器中取 

常量值,而是从内存中取,代码如下:

我们发现此时,const类型变量i的值是已经被改变了,则证明我猜想的思路也许是对的,又或许编译器

用了更复杂的方式处理,但是大概思路应该是这样吧

最后我们总结下:

前面说了那么多无非有以下两点:

1.C C++中的const变量是都要分配内存的。

2.C++只不过在编译的时候直接进行变量替换,同时在运行过程中直接在寄存器中取const变量的

   值,这是C++编译器优化的结果。

3.而对于C语言而言每次const使用都是直接从内存中取值,这样每次const变量的间接改变都能得到

   反映。

如果你有更好的理解欢迎一起讨论或者分享。

原文地址:https://www.cnblogs.com/vpoet/p/4771805.html