c - 将指针A分配给B。释放A后,B仍然存在

标签 c pointers malloc free

如果我声明指针***A和***B,为A分配内存,并说“B = A”, 我只需要释放“A”,对吗? 为什么我调用B[1][1][1]还能看东西?

代码是:

#include <stdio.h>
#include "../Toolbox/3DArray.c"

int main(void)
{
  double ***P1, ***P2;
  P1 = d_3DArray(2, 2, 2);

  P2 = P1;

  int i, j, k;
  for(i=1; i<=2; i++){
    for(j=1; j<=2; j++){
      for(k=1; k<=2; k++){
    P1[i][j][k] = k + 10*j + 100*i;
      }}}


  free_d_3DArray(P1);

  if(P2 == NULL) printf("P2 becomes a NULL pointer. \n");
  else printf("P2[1][1][1] = %.0lf \n", P2[1][1][2]);


  return 0;
}

输出为:

P2[1][1][1] = 112 

这正是 for 循环分配的值。 free_d_3DArray 是这样的:

void free_d_3DArray(double ***x)
{
  free(x[0][0]);
  free(x[0]);
  free(x);
}

但是如果我也输入 free_d_3DArray(P2); ,我会收到“段错误(核心转储)”。
我应该怎么办??

感谢您的任何回复!

更新
谢谢大家的回复。我现在明白了。我对这个愚蠢的问题感到抱歉(>u<)

最佳答案

在您的代码中:

P2 = P1;
free_d_3DArray(P1);
if(P2 == NULL) ...

P2 永远不会为 null,因为它具有 P1 所具有的值。释放 P1 并不会改变这一点。如果 P1 的值发生变化,则不会反射(reflect)在 P2 中。这是C语言中“难”的部分;你必须自己做所有事情;编译器除了编译你的语句之外不会做任何事情。

您仍然可以在 P2 中找到有效值,因为虽然内存已返回到堆以供重复使用,但堆管理器不必将内存归零等。因此,只要程序没有在其他地方重复使用内存,您仍然可以看到有效值。

关于c - 将指针A分配给B。释放A后,B仍然存在,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32257404/

相关文章:

C 结构体中多个不同的 union

c - 如何使用内存分配通过指针在数组中存储值

C - 新分配的 char* 包含现有数据

c - ARMv7 汇编语言 : How to add two uint32_t and return a uint64_t result

c - 如何获取SSDT地址

将字符串与特定模式进行比较

C编程,if语句(大到小整数交换)

c - 以下两个函数是否等价?如果不是,为什么不呢?

c - 如果满足条件,每次迭代都可以扩大数组吗?

c - 动态内存分配问题