指针和const限定符
1,指向const对象的指针
const double *cptr; //cptr may point to a double that is const
这里cptr是一个指向double类型的const对象的指针,const限定了cptr指针所指向的对象,而非cptr本身。也就是说cptr本身并不是const。在定义时不需要对他进行初始化。允许给cptr重新赋值,使其指向另一个const对象。但不能通过cptr修改其所指对象的值。
const double pi = 3.14;
cptr = π
*cptr = 42; //error:*cptr might be const
const double x = 2.3.;
cptr = &x //ok
意外收获:声明指针后,如果当时没有给指针赋初值,那么过后只能通过迅地址符,通过指针本身赋值,像下面*in = a;这样是非法的。
int a = 0;
int b = 1;
int *in;
//*in = a;
in = &a;
cout<<*in<<endl;
允许把非const对象的地址赋给指向const对象的指针,但是不能把一个const对象的地址赋给一个普通的,非const对象的指针。
const double *cptr;
double daval = 3.147;
cptr = &daval; //ok
const double pi = 3.14;
double *ptr = π //error
const double *cptr = π //ok
于是这里有一个问题,本来cptr这种指针,可以改变其指向的地址,但不能通过这个指针修改其指向的对象。但如果他指向的是一个非const类型的对象,那么该对象通过其他指向他的非cptr这种类型的指针是可以改变其值的,这也是一种修改的途径。ps:小困扰了我一下。
可以把指向const的指针理解成:自以为指向const的指针。
double dval = 3.14;
const double *cptr = &dval;
*cptr = 2.07; //error
double *ptr = &dval;
*ptr = 2.07;
cout<<*cptr<<endl; //prints 2.07
2,const指针
int errNumb = 0;
int *const curErr = &errNumb; //curErr is a constant pointer
curErr是指向int型对象的const指针。
const指针不能使其指向其他对象,但是可以使用该指针修改它所指向对象的值。
const指针必须在定义时候初始化。