概 述
如果我们只是 struct time *p;
我们只是创建了一个指针,只会在栈中分配指针大小的空间来存放地址,一般情况下占用4个或者8个字节的空间。(不清楚可以自己sizeof)
所以我们并没有开辟出一个结构体的空间,你只能新建一个结构体(正常的struct time x或者使用malloc),然后把结构体的地址赋值给p,它才能够正常运行。
如果想要开辟出空间,建议直接使用 malloc 来开辟,这样子内存上会直接开辟出N个结构体大小的空间给这个指针使用,我们就可以去初始化了
实验一
int main()
{
struct time *p;
(*p).min = 0;
(*p).hour = 1;
printf("%d", p->min);
}
实验二
{
struct time *p;
p->min = 0;
p->hour = 1;
printf("%d", p->min);
}
本以为这两种情况下都是有输出的,但是结果是报warning
warning: 'p' is used uninitialized in this function
但是如果我进行实验三
实验三
int main()
{
struct time t[2] = { {30, 5}, {50, 6} };
struct time *p;
p = &t[0];
p->min = 0;
p->hour = 1;
printf("%d", p->min);
}
实验三是可以正常运行的,也就是或结构体指针必须先创建一个结构体变量,然后把这个变量的地址赋值给指针后,这个指针才可以正常使用,而不能被单独赋值。
思考后结论: 如果我们只是 struct time *p;
我们只是创建了一个指针,只会在栈中分配指针大小的空间来存放地址,一般情况下占用4个或者8个字节的空间。(不清楚可以自己sizeof)
这么并不会在内存上开辟出一块空间给我们存放min和hour,
所以min和hour的空间你根本就没有,自然没办法去在这个空间上去填上值。
如果想要开辟出空间,建议直接使用 malloc 来开辟,这样子内存上会直接开辟出N个结构体大小的空间给这个指针使用,我们就可以去初始化了
int main()
{
struct time *p = (struct time *)malloc(sizeof(struct time) * 1);
p->min = 0;
p->hour = 1;
printf("%d %d", p->min, p->hour);
}
像这样子,就可以成功打印。
c语言结构体指针元素不能赋值 C语言结构体指针必须被结构体变量赋地址或malloc后才能正常使用 不能单独赋值?...