我使用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("%d\n", *ptr);
return 0;
}
显示10
的输出。
此处,使用ptr
函数为malloc
指针分配动态内存,然后ptr
保存i
varable的地址。
在C中写ptr = &i;
是否合法?
修改
那么,编译器是否有可能生成有关内存泄漏的警告?
答案 0 :(得分:6)
这不是非法的。它只是造成内存泄漏。你永远不会在这个程序实例中使用那个分配的内存。
你可能做了什么?
如果不需要,则根本不分配内存。
您可以存储该地址。
在覆盖存储在指针中的内容之前,您可以释放该内存。
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("%d\n", *ptr);
return 0;