1、指针保存的是另一个对象的地址。
int *pi = &ival;
int **ppi = π
*cptr = 42;
//error:*cptr might be const
int *const curErr = &errNumb; //curErr is a constant pointer
const pstring cstr;
2、一个有效的指针必然是以下三种状态之一:保存一个特定对象的地址;指向某个对象后面的另一个对象;或者是0值。若指针保存0值,表明它不指向任何对象。
3、把int型变量赋给指针是非法的,但允许把数值0或在编译时可获得0值的const量赋给指针。
4、特殊指针类型void * ,它可以保存任何类型对象的地址。void * 表明该指针与一地址值相关,但不清楚存储在此地址上的对象的类型。
5、指向指针的指针:指针本身也可用指针指向的内存对象。
如:int ival = 1024;
6、
指向const对象的指针:如果指针指向const对象,则不允许用指针来改变其所指的const值。
如:const double *cptr;
把一个const对象的地址赋给一个普通的、非const对象的指针也会导致编译时的错误:
const double pi = 3.12;
double *ptr = &pi ;
//error : ptr is a plain pointer
const double *cptr = π
//ok : cptr is a pointer to const
不能使用void*指针保存const对象的地址,而必须使用const void*类型的指针保存const对象的地址。
7、
const指针:本身的值不能修改。
如:int errNumb = 0;
curErr是指向int对象的const指针,意味着不能使curErr指向其他对象。
curErr = curErr ;
//error : curErr is const
8、typedef string *pstring;
const修饰的是pstring的类型,因此,该声明语句是把cstr定义为指向string类型对象的const指针,这个定义等价于:string *const cstr;