在C语言中,const是个伪常量
const int a =10;
int *p=(int *)&a;//把a强转为int
*p=20;
printf("a=%d\n",a);
//此时打印出来的a是20,C语言中的const只是一个可读的,还是能强制修改
在C++中const是不可修改的
const int a=10;
int *p=(int*)&a;
*p=20;
cout<<a<<endl;
//此时输出的a还是等于10;
原理:在c++中 如果定义一个常量,那么它会在内存开辟一个符号表:
key | value
a | 10
如果对一个常量取地址,编译器会临时开辟一个空间temp,让这个指针存放这个临时空间的地址
因此在
int *p=(int*)&a
取a的地址的时候并不是真正的取a的地址,而是取出编译器为a开辟的一个临时temp的地址,因此此时强转过去后修改的是temp的值,并不是a的值,所以c++中的常量是不会被修改的。
从以下代码也能看出:
const int a=10;
int b[a]={0};
这个代码在c++中是合法的,而在c语言中是会出错,因为c++中使用const就真正表示一个常量,而c语言中虽然被const修饰,但它还是一个变量