首先看两个例子
一、
二、
这两个例子里面不同的地方就是s的不同,C语言程序在执行的时候内存分配有这样的规则
局部变量在栈中自动生成内存,比如上面所说的s[]就是在栈中生成内存
而s*指向的内存在常量区,就类似于我们在所有程序之前声明char s[100]一样
栈由编译器自动生成释放,而常量区的内存是由操作系统决定的
回到咱们之前说的那个,两份代码返回的s都指向第一个字母的内存地址,第一个由于在常量区,所以一直存在,第二个在函数toStr函数执行之后内存就释放了,所以会报错
而像其他的写法
char *s;
s = “abcdefg”;
其实和第一种方法相同
char *s;
S[0] = ‘a’;
和第二种相同
char *只是一个指针,在第一句的时候还未指向内存
其他情况
这里的segmentation fault是发生在strcat里面的,这里面不能对指针直接操作,因为指针没有指向内存,后面的内存没法存储
这种情况是因为常量区的内存是无法进行修改,通过指针只能访问字符串常量,不能改变这个常量
所以以后有这种情况就思考这几点
1、直接对指针操作,指针都没指向内存肯定不能操作啊
2、试图访问一个不存在的内存地址,地址在栈中还是在哪里啊
3、是否有访问权限,我们不能修改当前执行的.c文件或者二进制文件,还有刚刚说的指针只能访问常量区的内存但是不能修改那样