質量参加の一次元アレイ
私たちは、本質的には、配列が引数として渡されるC言語、、、でポインタ引数(配信アドレス値を)やっていることを知っています。以下
/*
打印数组的元素值
*/
void printArr(int* arr,int len){
for (int i = 0; i<len; i++) {
//指针arr获取元素的方式可以使arr[i] 也可以使*(arr+i)
printf("%d \n",arr[i]);
}
}
int main(int argc,const char* argv[]){
int dataArr[] = {1,2,3,4,5};
printArr(dataArr,5);
int* dataArr2 = dataArr;
printArr(dataArr2, 4);
}
二次元配列パラメータの受け渡し
二次元アレイは、アクセス方法などのパラメータ「[]」として使用される場合には問題があります。
void printArr2(int arr[3][2],int len,int width){
for (int i = 0; i<len; i++) {
for (int j = 0; j<width; j++) {
printf("%d \n",arr[i][j]); //(OK)
}
}
}
void printArr3(int (*arr)[2],int len,int width){
for (int i = 0; i<len; i++) {
for (int j = 0; j<width; j++) {
printf("%d \n",arr[i][j]); //ok
}
}
}
void printArr4(int* (arr[3]),int len,int width){
for (int i = 0; i<len; i++) {
for (int j = 0; j<width; j++) {
// printf("%d \n",arr[i][j]); //(X)
printf("%d \n",(arr+2*i)[j]); //(X)
}
}
}
void printArr5(int ** arr,int len,int width){
for (int i = 0; i<len; i++) {
for (int j = 0; j<width; j++) {
printf("%d \n",*((int*)arr+i*width+j)); //通过线性计算
}
}
}
int void main(int argc,const char * argc[]){
int dataArr[][2]= {{1,2},{3,4},{5,6}};
printArr5((int **)dataArr,3,2);
}