对比下面代码:
const int a=0;
int *pa= (int *) &a;
cout<<pa<<endl; //0x61fe14
cout<<&a<<endl; //0x61fe14
*pa=20;
cout<<a<<endl; //0
cout<<*pa<<endl; //20
定义a是一个常量,并用0(右值)进行初始化,const认定a无法被改变。**即无法通过改变a来改变右值的值,但本身右值无法找到地址所以无法改变,因此a锁在地址无论怎么改变,都会被宏替换成0。**让pa指向&a,本质上不能通过改变*pa的值进而改变a的值,所以a还是0.*pa=20;
为什么pa和a的地址一样?值不一样?
const定义变量时默认进行宏替换,需要值时直接替换,类似define
普通的变量从内存中读入数据,因此可以存在地址相同,值不一样的情况。
int b=10;
const int a=b;
int *pa = (int *)&a;
cout<<&b<<endl; //0x61fe14
cout<<&a<<endl; //0x61fe10
cout<<pa<<endl; //0x61fe10
*pa=20;
cout<<*pa<<endl; //20
cout<<a<<endl; //20
先定义了一个变量b(左值),因为b是左值,用b的值初始化a的值,这时意义变成了不能通过改变b的值来改变a,但a本身是一个可以改变的值因此pa可以修改a的值。