作者热门文章
- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
如何在下一个程序中释放“v 结构”?
#include <stdio.h>
#include <stdlib.h>
struct Quaternion{
double r;
struct Q_vec{
double x;
double y;
double z;
} v;
};
int main(void){
struct Quaternion* q1Ptr = malloc(sizeof(struct Quaternion));
q1Ptr->r = 1.0;
q1Ptr->v.x = 2.0;
q1Ptr->v.y = 2.0;
q1Ptr->v.z = 2.0;
printf("%s = (%f, %f, %f, %f)\n", "q1", q1Ptr->r, q1Ptr->v.x, q1Ptr->v.y, q1Ptr->v.z);
free(q1Ptr);
printf("%s = (%f, %f, %f, %f)\n", "q1", q1Ptr->r, q1Ptr->v.x, q1Ptr->v.y, q1Ptr->v.z);
//Doesn't prints 'r', but prints x, y and z.
}
输出是:
q1 = (1.000000, 2.000000, 2.000000, 2.000000)
q1 = (0.000000, 2.000000, 2.000000, 2.000000)
所以,我不会删除指向 v 的指针。
还有,我的分配可以吗?
编辑:感谢您的所有回复!
这只是实际程序的一小部分示例,我并没有在释放指针后尝试使用它。我刚刚注意到内存的持久化,想知道我是否有内存泄漏以及如何避免它。
最佳答案
你误会了。 free()
不需要清除您分配的内存内容,并且 free()
不会更改指针 q1Ptr< 指向的内存地址
指向。 free()
只是将资源返回给操作系统(或任何分配给您的内存)。分配给该变量的值可以持续存在,并且不能保证被 free()
清零。在 free()
调用之后您仍然看到您分配的一些值这一事实并不表示 free()
调用失败。
但是,使用指向已被free
d 的内存的指针会导致未定义的行为,因为它仍指向您已分配的内存,但不再属于您使用或访问。在您的系统中,这一次似乎没问题,但您不能依赖它。
关于c - 在嵌套结构上使用 free,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48996845/
我是一名优秀的程序员,十分优秀!