如果再栈上分配指针字符串空间,则改变指针内容会有“段错误”,代码:
char *str = "good";
*str = 'X';
printf("%s",str); //会出错
但如果通过动态内存分配指针字符串空间,则不会出现这样的错误,代码:
char *str = malloc(20);
strcpy(str,"good");
*str = 'X';
printf("%s",str); //执行通过,打印“Xood”
呵呵,第一种情况是字符常常量,他的存储位置是位于数据段,系统保护的内存空间,属于只读的。指针只是指向这个存储空间而已,如果对其内容修改的话,其行为是未定义的;
第二种情况下str指向的是堆内存空间,只是把字符串拷贝到自己的存储空间了,当然可以修改了。
char *str = "good";
*str = 'X';
printf("%s",str); //会出错
但如果通过动态内存分配指针字符串空间,则不会出现这样的错误,代码:
char *str = malloc(20);
strcpy(str,"good");
*str = 'X';
printf("%s",str); //执行通过,打印“Xood”
呵呵,第一种情况是字符常常量,他的存储位置是位于数据段,系统保护的内存空间,属于只读的。指针只是指向这个存储空间而已,如果对其内容修改的话,其行为是未定义的;
第二种情况下str指向的是堆内存空间,只是把字符串拷贝到自己的存储空间了,当然可以修改了。