char* p = "test";————test保存在常量区中
char *str = "Hello world"; <===> const char *str = "Hello world";
利用指针p来改变字符串test的内容都是错误的非法的。
例如:
p[0] = 's';
strcpy(p, "haoel"); 这都是错误的操作。
原因就在于,char* p = "test"; 这个声明,声明了一个指针,而这个指针指向的是全局的const内存区,
const内存区当然不会让你想改就改的。所以,如果你一定要写这块内存的话,那就是一个非常严重的内存错误
注意!!!!
“字符串常量是保存在只读内存里的。 ”
--------------------------------------------------------------------------------------
char *p = "abcd";
*p = 'b';
printf("%c\n", p[0]);
以上代码有什么问题?
首先,编译器在常量区保存一个字符串abcd,其内容不许修改。
采用指针存储字符串,其实质就是把字符串的首地值附给基类型为char的指针变量,从而可以从字符串首元素开始对字符串进行操作,这里面也存在一点问题.
运行结果会出现段错误,原因在于,*p="abcd" 这句仅仅声明了一个指针变量,指向字符串"abcd",而"abcd"这个字符串程序没有给它分配空间,编译器把它分配到常量区.而常量字符串的值是不允许被修改的 ,所以会出现段错误.
应该:
char p[12]="abcd";
char *p1=p;
p1[0]='H';
printf("%s\n",p1);
p[12]="hello world"
自己定义的一个长度为12的字符数组,所以字符串"abcd"编译器会给它分配空间(在栈中),所以你能修改它的值.
char *str = "Hello world"; <===> const char *str = "Hello world";
利用指针p来改变字符串test的内容都是错误的非法的。
例如:
p[0] = 's';
strcpy(p, "haoel"); 这都是错误的操作。
原因就在于,char* p = "test"; 这个声明,声明了一个指针,而这个指针指向的是全局的const内存区,
const内存区当然不会让你想改就改的。所以,如果你一定要写这块内存的话,那就是一个非常严重的内存错误
注意!!!!
“字符串常量是保存在只读内存里的。 ”
--------------------------------------------------------------------------------------
char *p = "abcd";
*p = 'b';
printf("%c\n", p[0]);
以上代码有什么问题?
首先,编译器在常量区保存一个字符串abcd,其内容不许修改。
char *p = "abcd"; // p是一个指针,直接指向常量区,修改p[0]就是修改常量区的内容,这是不允许的。
采用指针存储字符串,其实质就是把字符串的首地值附给基类型为char的指针变量,从而可以从字符串首元素开始对字符串进行操作,这里面也存在一点问题.
运行结果会出现段错误,原因在于,*p="abcd" 这句仅仅声明了一个指针变量,指向字符串"abcd",而"abcd"这个字符串程序没有给它分配空间,编译器把它分配到常量区.而常量字符串的值是不允许被修改的 ,所以会出现段错误.
应该:
char p[12]="abcd";
char *p1=p;
p1[0]='H';
printf("%s\n",p1);
p[12]="hello world"
自己定义的一个长度为12的字符数组,所以字符串"abcd"编译器会给它分配空间(在栈中),所以你能修改它的值.