我们都用过const 修饰符修饰一个变量,而且我们知道使用const修饰之后,这个变量相当于常量了,他的值在代码其他部分不能再修改,这对于函数调用时候,防止错误的修改原本不应修改的变量起到很大作用,举个例子,加入A函数调用B函数进行字符串处理,A把字符串的地址传递给B,B在处理过程中误修改了字符串的地址,导致程序出错,有时候这种错误很难找到,这时候我们就可以使用const关键字。
可是对于指针的情况,我们不想修改指针指向的地址,但是允许修改指针指指向的地址中的值,该怎么做呢,可以这么理解这段话,如果char * a = ptr,那么a不能在指向其他的地址,但是对于*a的赋值是可以的。那么如果我们写const char *或者char const *或者
char * const,哪一个是我们需要的呢?看一段代码。
1 #include <stdio.h>
2 int main(void)
3 {
4 char buf[] = "hello world";
5 char buf2[] = "world hello";
6 const char* a = buf;
7 char const* b = buf;
8 char* const c = buf;
9 //*a = 'x';
10 //*b = 't';
11 *c = 't';
12 a = buf2;
13 b = buf2;
14 //c = buf2;
15 printf("a is %s\nb is %s\nc is %s \n", a, b, c);
16 return 0;
17 }
如果我把第8行第9行的注释去掉,编译的时候会发生如下错误:(编译环境gcc)
test.c: In function `main':
test.c:9: error: assignment of read-only location
test.c:10: error: assignment of read-only location
如果14行注释去掉会发生如下错误:
test.c: In function `main':
test.c:14: error: assignment of read-only variable `c'
好了我么总结一下,const char *与char const* 效果一样,都是不允许修改指针指向的地址空间的值,即把值作为常量,而char * const则是不允许修改指针自身,不能再指向其他地方,把指针自己当作常量使用。需要注意的是,使用char * const 定一个常量指针的时候一定记得赋初始值,否则再其他地方就没法赋值了。