一个容易忽略的陷阱:修改字符串常量的值

见下面例子:

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';

posted on 2010-06-16 14:46  highmayor  阅读(378)  评论(0编辑  收藏  举报

导航