首页 > 代码库 > C语言堆内存管理上出现的问题,内存泄露,野指针使用,非法释放指针
C语言堆内存管理上出现的问题,内存泄露,野指针使用,非法释放指针
C语言堆内存管理上出现的问题,内存泄露,野指针使用,非法释放指针
(1)开辟的内存没有释放,造成内存泄露
(2)野指针被使用或释放
(3)非法释放指针
(1)开辟的内存没有释放,造成内存泄露,下面的例子就可能造成20个字节的泄露,内存泄露不是一个立即会引发故障的错误,但是
它将消耗系统内存。
void function1() { char *pa; pa = (char*)malloc(sizeof(char)*20); if(NULL !=pa) { strcpy(pa,”hello”); printf(“pa = %x\n”,(unsigned int)pa); printf(“pa = %s\s”,pa); } return; }
(2)野指针被使用或释放
野指针是一个已经被释放的内存指针,他指向的位置已经被使用free或者realloc函数释放了,但是该指针依然在使用。
void function2() { char *pa; pa = (char*)malloc(sizeof(char)*20); if(NULL !=pa) { strcpy(pa,”hello”); printf(“pa = %x\n”,(unsigned int)pa); printf(“pa = %s\s”,pa); } free(pa); printf(“ pa = %s”,pa); return; }
正确的内存释放应该是下面的
void function2() { char *pa; pa = (char*)malloc(sizeof(char)*20); if(NULL !=pa) { strcpy(pa,”hello”); printf(“pa = %x\n”,(unsigned int)pa); printf(“pa = %s\s”,pa); } free(pa); pa = NULL; if(NULL != pa) { printf(“pa = %s\n”,(unsigned int)pa); } return; }
(3)非法释放指针
void function3() { char a[20]; int b; free(a); free(&b); return; }
上面的程序中,a[20]是一个栈上的数组,a是这块内存的地址;b是栈上面的一个变量,&b是它的地址。这些栈上的内存,编译器
将自动管理和回收资源,程序中使用free将他们释放,是一种错误的写法。
char *pa; pa = (char*)malloc(sizeof(char)*20); free(pa); free(pa);
上面的一段程序,将内存释放两次是错误的写法,因为第一次释放后,该地址已经变成,未分配的堆内存,free函数不能释放未分配的堆内存。
char *pa; char *pa; pa = (char*)malloc(sizeof(char)*20); pb = pa++; free(pb);
在上面的程序中,虽然pa是一个被分配出的堆内存指针,pb作为pa的地址加1,也是一个堆内存的指针,而且这个指针所指向的也是已经分配的内存。然而内存pb依然是非法的内存释放。这是由于这个指针并不是从malloc分配出来的,而是中间的一个指针值。
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。