OsChina上一个朋友给出的例子,很能说明问题:
typedef char * CharPtr; const CharPtr mycharptr = "Hello, World"; mycharptr[0]='h'; //OK[1] mycharptr = "It's Wrong"; //Err[2]
如果把CharPtr替代掉的话,那么似乎[1]是错的,[2]是对的,因为const char *是指向const char的指针,指针可以指向别的,但是指向的内容不能变。实际上,const只是编译器的一种规范,所以编译的时候只按照语法检查是不是改变了,char*被typedef之后,可以当成一种简单类型看,那么const CharPtr 就只一个CharPtr型的常量,对它的赋值肯定会引起编译错误,而[0]这种寻址并不影响。
不过,如果把typedef 改为宏替换(如下),事情就不一样了,毕竟宏替换只是一种替换而已,不会引起编译器的检查,编译之前,CharPtr就已经被替换掉了。
#define CharPtr char *
const CharPtr mycharptr = "Hello, World"; mycharptr[0]='h'; //Err mycharptr = "It's Wrong"; //OK
本文通过具体的代码示例,深入探讨了C语言中const限定符与指针结合使用时的行为特性,解释了为什么某些操作是合法的,而另一些则会导致编译错误。
1185

被折叠的 条评论
为什么被折叠?



