问题描述:bug1:创建了一个结构体指针,通过malloc动态开辟内存的方式开辟了一段内存空间,然后进行写入数据修改数据的操作,但是下面的代码会导致内存泄露:
typedef struct{
int name;
int sex;
}Data_struct;
Data_struct* data_receive(void)
{
Data_struct* msg=(data*)malloc(sizeof(Data_struct)); //开辟内存,并写入数据
msg->name=123;
msg->sex=0;
return msg;
}
int main()
{
Data_struct* msg = (Data_struct*)malloc(sizeof(Data_struct)); //开辟内存
msg=data_receive(); //写入初始化数据
msg->name=321;
msg->sex=1; //修改数据
free(msg); //释放内存
}
原因分析:上述代码中接口data_receive中使用了一个malloc,在main函数中同样使用了一个malloc,但是只有在main中释放了一次,因此会导致内存泄露
int main()
{
Data_struct* msg =data_receive();
msg->name=321;
msg->sex=1; //修改数据
free(msg); //释放内存
}
解决方法:内存泄露的错误往往是很难查找的,如果使用的是IAR编译器的话,可以使用下面的接口进行跟踪和调试:
#include<iar_dlmalloc.h>
struct mallinfo heap_meninfo;
heap_meninfo=_iar_dlmallinfo();
printf("heap alloc==%d free==%d\n",heap_meninfo.uordblks,heap_meninfo.fordblks);
|