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

程序初学者

上下文

我创建了这个简单的代码,我将各种数组存储在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()I 然后遍历子数组并遍历每个单独的数字并将其打印出来。

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

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

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

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

为什么?

欧姆

In my_arrays,array_1array_2是堆栈上的本地数组。您从 返回后,它们将立即失效my_array现在arrays[0]arrays[1]持有指向无效或“陈旧”内存的指针。访问这是未定义的行为。

(您看到的垃圾值表明您的数组已被堆栈空间的其他用途覆盖,可能是通过调用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]);
}

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章