问题描述
- 关于free空指针问题。。。
-
char *a="fsdfsds";while(a != NULL)
a++;free(a); 这样会段错误,那么如果 char *a="fsdfsds"; char *b; b = a;
while(a != NULL)
a++;free(a); 这样a被free了。但是b不也是泄露了么?
解决方案
解决方案二:
1、malloc()到底从哪里得到了内存空间?答案是从堆里面获得空间。也就是说函数返回的指针是指向堆里面的一块内存。操作系统中有一个记录空闲内存地址的链表。当操作系统收到程序的申请时,就会遍历该链表,然后就寻找第一个空间大于所申请空间的堆结点,然后就将该结点从空闲结点链表中删除,并将该结点的空间分配给程序。关于堆的知识呢可以查询数据结构方面的知识或查询以前的一篇帖子C/C++堆、栈及静态数据区详解[转载]。这里不过多介绍。
2、在使用malloc()分配内存空间后,一定要记得释放内存空间,否则就会出现内存泄漏。
3、free()到底释放了什么
free()释放的是指针指向的内存!注意!释放的是内存,不是指针!指针并没有被释放,指针仍然指向原来的存储空间。指针是一个变量,只有程序结束时才被销毁。释放了内存空间后,原来指向这块空间的指针还是存在!只不过现在指针指向的内容的垃圾,是未定义的,所以说是垃圾。因此,释放内存后把指针指向NULL,防止指针在后面不小心又被解引用了。
以上是经典解释~空指针可以无限释放的。
解决方案三:
用malloc分配的,才用free释放,否则别乱用
解决方案四:
我都没看到你分配内存,你在那FREE啥啊?
你要FREE文字常量区?
第一个,你搞了个字符常量的指针,还自加,然后去FREE,最后你很可能非法访问内存,因为你试图去释放一段不是你MALLOC出来的内存。
第二个,在释放的手段是和第一个犯同样的错误,同时,假设你只正常申请了内存的,再使用FREE去释放,但是一段内存只需要释放一次。B 和 A 存储了相同的内存地址,建议你好好看下程序的内存分配,比方常量区,全局区,堆,栈,等等。看多了你就懂了。
解决方案五:
不论是const char *p="aaa",还是char *="aaa"
实际上p指向的是数据区的字符串,这块内存不是堆上的内存,不需要free释放;
free只释放堆上的内存,注意与malloc配套使用