《c专家编程》p19-p20页中的代码:
char *cp;
const char *ccp;
ccp = cp;
书中介绍是合法的。
但是反过来就不能进行赋值
cp = ccp; /* 结果产生编译警告 */
上述合法的原因:
1. 左操作数是一个指向有const限定符的char的指针。
2. 右操作数是一个指向没有限定符的char的指针。
3. char类型与char类型是相容的,左操作数所指向的类型具有右操作数所指向类型的限定符(无),再加上自身的限定符(const)。
这三条符合ANSI C第6.3.16.1节的约束条件:
两边操作数都是指向有限定符或无限定符的相容类型的指针,左边指针所指向的类型必须具有右边指针所指向类型的全部限定符。
个人理解:
const char* ccp中的const修饰的是指针所指向的类型(char),而不是指针本身。
ccp是一个指向常量字符型的指针。这个指针不能用于修改这个字符型数,但是在任何时候,这个指针本身的值却可以改变。
也就是说可以给ccp赋任何的指向字符型的地址(0xaaaaaaaa, 0xbbbbbbbb, 0xcccccccc等等等等),但是它不能改变这个地址所存的值。而cp这个指针就没有任何限制。
所以在cp = ccp的时候,cp是能修改这个字符型值的。而ccp是不可以修改的。所以会产生编译警告