一.结论
先来说结论,当你的参数传入是通过赋值的方式,就定义指针属性,当你的参数传入是通过scanf()的方式,就选择数组.
二.原因
原因很简单,当我们将结构体中定义指针这个属性,那么应该是下面这种格式,也就是指针并没有指向一个具体的值,相当于野指针.而scanf这种录入数据的方式,是需要一块连续的地址空间来存储它赋的数据,那么,我们再通过scanf这种方式去给指针赋值,就相当于向一个无效的地址内存写入数据,会导致未定义行为或直接崩溃.
但当我们用数组接收scanf数据的时候,因为数组在定义时就已经开辟了一块连续的内存空间,所以直接存入数据没有问题,但要小心数组大小溢出
三.解决方案
如果一定要定义指针类型属性,那么当我们想通过scanf函数对指针指向的地址赋值之前,需要用malloc函数或者calloc函数对此指针进行动态内存分配,也就是使原本没有内存空间的地址创建几个字节的空间,这样就可以接收scanf传进来的数据,代码如下
#include <stdio.h>
#include <stdlib.h>
struct Person
{
int age;
char *name;
};
int main()
{
struct Person p;
// 不能直接scanf录入数据,除非提前动态初始化
p.name =calloc(10,sizeof(char));
if(p.name == null)
{
printf("内存创建失败\n");
return 1;
}
scanf("%s", p.name);
printf("%s\n", p.name);
//动态创建完一定要释放内存空间
free(p.name);
return 0;
}
1115

被折叠的 条评论
为什么被折叠?



