我使用gcc prog.c -Wall -Wextra -pedantic -std=gnu11
命令在GCC上编译了以下代码。它不会生成任何警告或错误。
法典:
#include <stdio.h>
#include <stdlib.h>
int main()
{
int i = 10;
int *ptr = malloc(1);
ptr = &i; // is it legal?
printf("%dn", *ptr);
return 0;
}
显示10
的输出。
在这里,使用malloc
函数为指针分配ptr
动态内存,然后ptr
保存i
变量的地址。
用 C 语言编写ptr = &i;
是否合法?
编辑:
那么,编译器是否可以生成有关内存泄漏的警告?
这并不违法。它只是造成内存泄漏。您将永远无法在该程序的此实例中使用该分配的内存。
你能做什么?
-
如果不需要,则根本不分配内存。
-
您可以存储该地址。
-
在覆盖指针中存储的内容之前,您可以释放该内存。
int i = 10; int *ptr = malloc(1*sizeof(int)); int *stored; if(ptr == NULL){ fprintf(stderr,"Error in Malloc"); exit(1); } stored = ptr; // avoiding memory leak. ptr = &i; free(stored); printf("%dn", *ptr); return 0;