从 void 双指针数组输出 void 指针

Output void pointer from void double pointer array

我需要实现一个包含空指针的可变长度数据数组。我 运行 遇到的问题是,当尝试从这个数组打印时,我总是输出最后一个元素。 这是我的问题和尝试实施的抽象说明:

#include <stdio.h>
#include <stdlib.h>

int main() {
    int capacity = 4; // for example

    void **array = malloc(capacity*sizeof(void*));
    // assign values to array elements
    for(int i = 0; i < capacity; i++) {
        array[i] = malloc(sizeof(void*)); // not sure if it necessary
        int a = i*i;
        array[i] = &a;
        printf("index: %d, element: %d\n", i, *(int*)array[i]); // for demonstration
    }
    printf("\n");
    /*
    * after that I try to print all the elements of the array sequentially
    */
    for(int i = 0; i < capacity; i++) {
        printf("index: %d, element: %d\n", i, *(int*)array[i]));
    }

    // I know that I do not free my memory, but that’s not the point
    return 0;
}

我得到的输出如下:

index: 0, element: 0
index: 1, element: 1
index: 2, element: 4
index: 3, element: 9

index: 0, element: 9
index: 1, element: 9
index: 2, element: 9
index: 3, element: 9

(编辑问题:在评论中他们向我指出错误在于将变量放入质量中的方式,因为我没有考虑for循环中变量的生命周期和指针的原理) 如何在不引入一堆额外变量的情况下正确填充类似的数组?还是我选择的方法完全不正确? 如有任何帮助,我将不胜感激

您会看到 "last element",因为 a 在每次迭代中都停留在堆栈的相同位置,因此 &a 将特定的单个地址存储到所有元素中。然后该地址包含写入的最后一个值 - 直到当其他任何东西覆盖它时它变成完全垃圾。

您需要不同的地址,因此您需要在循环内为每个数字分配内存。已经发生了哪种情况,只是你为 void* 分配内存,而你需要 int,然后覆盖它,(正如评论已经指出的那样)你根本不应该这样做:

array[i] = malloc(sizeof(int));
*(int*)array[i] = i*i;
printf("index: %d, element: %d\n", i, *(int*)array[i]); // for demonstration

然后它起作用了:https://ideone.com/dF4KY8(一个额外的 ) 已从末尾删除)
当然,正如您自己的评论所暗示的那样,您需要 free() 内容。

希望能帮到你

  1. malloc 保留 space(您可能已经知道)和 returns void*,而不是 void**。我会初始化它:

    const int capacity = 4;
    int* array = (int*)malloc(capacity*sizeof(int)); 
    

我不会将数组初始化为 void** 因为你打算在其中存储许多整数 它和一个 int 数组就是一个 int*。 如果您已经在开始时初始化了数组,则不必 再次调用 malloc。 'malloc', returns地址,分配内存的地方 对你来说,但你已经知道,你想在哪里存储数据。如果你有一个 void**,是一个多维数组。剩下一件事:在失败时 malloc returns 一个空指针检查数组是否为空,不会伤害你。 :)

  1. printf() 中的 ')' 过多;