前端之家收集整理的这篇文章主要介绍了
在C程序中为同一个指针调用“自由”两次是否有任何伤害?,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
如果我有一个c程序,就像:
SomeTypePtr my_type;
my_type = malloc(sizeof(someType));
/* do stuff */
free(my_type);
/* do a bunch of more stuff */
free(my_type);
对my_type的“free”的呼叫是否有任何伤害?在我调用free(my_type)后,指针是否再次成为空指针?
释放内存区域不会使指针的
内容为空.假设你有int * a = malloc(sizeof(int)),而且有一个0xdeadbeef,你可以执行一个空格(a),然后在执行后仍然包含0xdeadbeef,但是在免费
调用后,这个内存地址不再保留给你.像你已经租了一个公寓,malloc用了一段时间,然后自由回来,所以你可能会有一个重复的钥匙,但它不是为你保留的.
在已经释放的内存上执行自由可能会导致双重可用内存损坏.
原文链接:https://www.f2er.com/c/112326.html