我创建了这个简单的代码,我将各种数组存储在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_1
和array_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] 删除。
我来说两句