一个容易忽略的陷阱:修改字符串常量的值
见下面例子:
int main()
{
char *p = "1234";
p[2] = '1';
return 0;
}
编译时通过,但执行时发生coredump, 原因是试图修改字符串常量的值: "1234"为一字符串常量,编译器有可能把它放在内存的只读区域,而p[2] = '1'试图对此字符串常量作修改,则会产生错误(当然啦,编译器也有不一定会把它放到只读区域,但这种情况应当避免)。。
另外,如果程序中有出现 两个或更多的字面值完全相同的字符串,如:char *p1 = "house";
char *p2 = "house";
那么编译器也有可能将它们存储在相同的位置,即“共用同一个字符串常量”,这样的话,如果修改其中一个字符串,就会影响到其它字符串。
然而,如果使用一个字符串来初始化一个数组,则是可以修改数组的内容的。
char a[] = "house";
s[0] = 'm';