从两个例子谈起:
#include <stdio.h>
int main()
{
char str[] = "hello C" ;
str[0] = 'j' ;
printf("a = %s\n" , str ) ;
return 0 ;
}
运行结果:
#include <stdio.h>
int main()
{
char * p = "hello , world" ;
p[0] = 'j' ;
printf("p = %s\n", p ) ;
return 0 ;
}
这个例子是会出现运行错误的。
原因就是:在第一个例子中字符串常量被copy到一个字符串数组中,因为字符串str存储的位置在一个字符数组里,在内存中的位置是栈。而第二个例子中的字符串是一个字符串常量,p = "hello C";并没有发生复制。只是使用一个字符指针指向了这个字符串常量的首地址。因为字符串常量存储的位置是在内存的全局常量区,因为这个区是只读的,所以在进行将第一个字符改变的操作时会发生错误,导致程序崩溃。
实际上,字符串数组也没什么特别,只是存储的内容是字符类型而已。需要注意的是,C字符串的特点是最后以一个’\0'结尾。在第一个程序中,存储在全局静态区的字符串常量的末尾是存在一个'\0'的;当把”hello world"复制给一个字符数组时,在最后也会给这个字符数组的最后添加一个'\0'。