在使用 Matlab 多年之后,我对 C 语言的数值分析还是个新手。我有一个构造数组的函数,我需要将它返回到 main()。我在数组与指针方面遇到了常见的麻烦,并通过摆弄找出了如何做到这一点。但摆弄给我留下了一个基于以下代码的概念性问题。
#include <stdio.h>
void array_set(int y_out[2][2]);
void int_set_wrong(int y);
void int_set_right(int *y);
int main (int argc, const char * argv[]) {
int y_array[2][2]={{0,0},{0,0}};
int y_int_1 = 0;
int y_int_2 = 0;
array_set(y_array);
int_set_wrong( y_int_1 );
int_set_right( &y_int_2 );
printf("\nValue array: %d \n",y_array[0][0]);
printf("Value int wrong: %d \n",y_int_1);
printf("Value int right: %d \n",y_int_2);
return 0;
}
void array_set(int y_out[2][2]){
y_out[0][0] = 10;
y_out[1][0] = 20;
y_out[0][1] = 1;
y_out[1][1] = 2;
}
void int_set_wrong(int y){
y = 10;
}
void int_set_right(int * y){
*y = 10;
}
上面的代码片段返回:
值数组:10
值 int 错误:0
右值 int: 10
我的问题分为几个部分,
首先,为什么函数“array_set”起作用?我希望它会像“int_set_wrong”一样失败。
顺便说一下,int 和 int 数组的处理方式有何不同?
此外,在“int_set_wrong”的情况下,是否有 y 的本地版本?
如果是这样,为什么在设置数组时没有本地版本的 y_out ?
谢谢您的帮助。顺便说一句,如果有任何事情会导致我的 array_set 实现出现问题,请插话。
--Andrew