C - 双指针数组 - 没有得到正确的值

C - Double pointer array - not getting correct values

上下文

我创建了这个简单的代码,其中我将各种数组存储在 my_arrays() 函数中,不同的函数(在我的示例中是 main())可以通过函数 my_arrays().

在此处查看代码:

#include <stdio.h>

int my_arrays(int *size, int **arrays) {
    size[0] = 3;
    int array_1[3] = {1, 2, 3};
    arrays[0] = array_1;

    size[1] = 5;
    int array_2[5] = {2, 3, -5, 7, 11};
    arrays[1] = array_2;
}


int main() {
    int num_of_arrays = 2;
    int sizes[2];
    int *arrays[2];
    my_arrays(sizes, arrays);

    for (int i=0; i < num_of_arrays; i++) {
        int *array = arrays[i]; // point to sub-array
        int size = sizes[i];

        printf("array[%d]: {", i);
        for (int x=0; x < size; x++) {
            printf(" %d", array[x]);
        }
        printf(" }\n", i);
    }
    return 0;
}

然后在 main() 中循环遍历子数组并循环遍历每个单独的数字并将其打印出来。

我希望上面的代码打印出来的是:

array[0]: { 1 2 3 }
array[1]: { 2 3 -5 7 11 }

但是在编译时 运行 我得到了这个:

array[0]: { 1993067712 1617605192 -2 }
array[1]: { 3936256 8 6422188 7 6422476 }

为什么?

my_arrays中,array_1array_2是栈上的局部数组。一旦您从 my_array return,它们就会失效。现在 arrays[0]arrays[1] 持有指向无效或“陈旧”内存的指针。访问是未定义的行为。

(您看到的垃圾值表明您的数组已被堆栈的其他用途覆盖 space,可能是通过调用 printf。)

如果要创建数组,可以在堆上分配内存:

int my_arrays(int *size, int **arrays)
{
    size[0] = 3;
    arrays[0] = malloc(3 * sizeof(int));
    
    arrays[0][0] = 1;
    arrays[0][1] = 2;
    arrays[0][2] = 3;

    // ... initialize other arrays ...
    
    return 0;
}

您应该在使用完后明确释放它:

// at the end of main

for (int i=0; i < num_of_arrays; i++) {
    free(arrays[i]);
}