C和C++中const的区别
众所周知,C和C++中用const修饰的变量初始化完成后,值不能被修改,不能再作为左值。
#include <stdio.h>
int main()
{
const int a = 10;
a = 20;
}
不管是在C还是C++中,上面的代码都是不能被编译通过的。而在C和C++中,const的使用还是有很多不同的。
初始化
在C++中,const修饰的变量必须要初始化,否则编译不通过;而在C中,const修饰的变量是可以不用初始化的,但如果const修饰的变量不初始化,我们也就没有机会重新给它赋值,一般还是建议在定义的时候初始化。
常量和常变量
在C中用const定义的变量称为常变量,虽然我们不能直接修改它的值,但是我们可以通过指针类型强转,间接修改它的值:
#include <stdio.h>
int main()
{
const int a = 10;
int* p = (int*)&a;
*p = 20;
printf("%d %d %d", a, *p, *(&a));
}
创建一个名为main.c的文件,运行结果如下: 可以看到a的值已经被改变了。
而用上面的代码创建一个main.cpp的文件,运行的结果如下: 可以看到虽然*p的值被修改了,但和a和*(&a)的值都没有被改变。
而造成这种结果的原因,是因为在C和C++中对const的编译方式不同。 在C中,const就是当作一个变量来编译生成指令;而在C++中,所有出现const常量名字的地方,都被其初始值替换了,如上面的printf("%d %d %d", a, *p, *(&a)); 这行代码在C++中实际是这样执行的 printf("%d %d %d", 10, *p, *(&10)); ,但实际上p 指向的这块内存的值已经被修改了,所以*p 输出的结果是20。
在C++中,const被当作常量的前提是它的初始化必须要是一个字面值,当我们用另一个变量来初始化时就会退化为常变量,编译规则就和C中一样了: 常量和常变量还有一个区别就是,常量可以用来定义数组,而常变量时不允许的:
|