在C程序中为同一个指针调用“自由”两次是否有任何伤害?

前端之家收集整理的这篇文章主要介绍了在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用了一段时间,然后自由回来,所以你可能会有一个重复的钥匙,但它不是为你保留的.

在已经释放的内存上执行自由可能会导致双重可用内存损坏.

猜你在找的C&C++相关文章