用以下代码printf("%s\n",p);可以打印出“hello world”
以下代码产生了段错误,要想理解这个段错误是如何产生的。
直接原因是指针p是野指针.
为什么p是野指针???
明白这两点:
1:当func执行结束后,会释放存放str的这段空间,而不是str指向的那段地址空间。
2:在func中对str赋值,并不等同于对p赋值。换句话说修改str并不等同于修改p;
只有当str是p的地址时。我们修改*str,才等同于修改p;
例如:
int a = 5;
int b = &a;
此时,我们修改b就等同于修改a得值;
上面的str和p都是一级指针;修改str怎么能等同于修改p呢?????
竟然还天真的以为,str = “hello world”;就等同于p = “hello world”;
只有让str等于p的地址,然后我们操作*str,就等同于操作指针p;
代码修改如下
https://blog.csdn.net/dianqicyuyan/article/details/123170283
我们让str 等于p在func中,把str指向了“hello world”的首地址,假如“hello world”的首地址时0x12345678。那么str = 0x12345678;
注意是str = 0x12345678;而不是str指向的内容等于0x12345678;
在func中,把str指向了“hello world”的首地址,假如“hello world”的首地址时0x12345678。那么str = 0x12345678;
注意是str = 0x12345678;而不是str指向的内容等于0x12345678;
void func(char *str)
{
str = “hello world”;
}
void main(void)
{
char *p = NULL;
func§;
printf("%s\n",p); //段错误
}
区分一下 指针p的地址 和p所指向的空间的地址
区分以下四种操作:
操作一级指针所指向的内存空间
操作一级指针本身
操作二级指针所指向的内存空间
操作二级指针本身
刚开始p指向NULL;
把p传到func时,str = p = NULL;
此时str也指向NULL,p和str都指向NULL;
要想做到在func中操作str就等同于操作p,那就要让str的地址等于p的地址;而不是str本身等于p本身。
在func中,把str指向了“hello world”的首地址,假如“hello world”的首地址时0x12345678。那么str = 0x12345678;
注意是str = 0x12345678;而不是str指向的内容等于0x12345678;
此时p还等于NULL;
如果func的参数是p的地址
str = p;
这句话意味着str和p指向同一块内存空间,修改str等同于修改p,但修改str并不等同于修改p;这里的*str理解为str解引用,即str所指向的内容。
如果你想做到修改str就等同于修改p,。。。。。。
注意:这并不意味着p现在也等于NULL。这是很关键的一点,搞明白这点,就不会混淆了。
str = “hello world“;这句话把”hello world”的首地址给了str;
这里操作的是str本身,并非str所指向的内存空间;
当func执行结束时,释放的是存放str的内存空间,而不是str所指向的内存空间。
char a = 10;
char *p = NULL;
char **w = NULL;
p = &a;
w = &p;