指针散碎知识点

char *Getstr()
{
    char *q=NULL;
    scanf("%s",q);
    return q;
}
char *Getstr()
{
    char a[80];
    scanf("%s",a);
    return a;
}

第一个的代码是错误,编译不出错,但是运行会出错;原因是指针p指向的地址是NULL,键盘输入的值无法存在NULL上。(常会误解为键盘输入的值需要地址来存,指针能存地址,为什么不中类,正解:键盘输入的是值,地址只能由计算机分配,不能由用户输入)。但如果令p=a;那么第一个代码就中啦。代码二用数组存,数组是计算机分配的可存储空间,所以代码二中

野指针:

#include <stdio.h>
char *Getstr()
{
    char a[80];
    scanf("%s",a);
    return a;
}

int main()
{
    char *p=NULL;
    printf("%p\n",p);
    p=Getstr();
    printf("%p\n",p);
    return 0;
}

运行结果是:

这里写图片描述
地址是传过来了,但是地址上的内容随着出栈释放了。这时主函数指针p就成了野指针。
指向垃圾内存的指针,就被称为野指针

猜你喜欢

转载自blog.csdn.net/FLwbf/article/details/79425902