C/C++二维数组的传参方法总结

来源:互联网 发布:mac 壁纸 编辑:程序博客网 时间:2024/05/16 07:33

C/C++二维数组的传参方法总结

转自:http://blog.csdn.net/gqb_driver/article/details/8886687

C/C++语言将二维数组作为参数传递容易使人迷惑且易出错,本文将常用的几种方法列出,以方便用时查阅。三+一种方法总结如下(GCC验证成功):

方法一:形参为二维数组并给定第二维长度
 此方法是最简单最直观的方法,形参与实参一样,容易理解。

举例:

[cpp] view plaincopy
  1. #include <stdio.h>  
  2.   
  3. void subfun(int n, char subargs[][5])  
  4. {  
  5.     int i;  
  6.     for (i = 0; i < n; i++) {  
  7.         printf("subargs[%d] = %s\n", i, subargs[i]);  
  8.     }  
  9. }  
  10.   
  11. void main()  
  12. {  
  13.     char args[][5] = {"abc""def""ghi"};  
  14.     subfun(3, args);  
  15. }  

方法二:形参为指向数组的指针并给出数组长度

举例

[cpp] view plaincopy
  1. #include <stdio.h>  
  2.   
  3. void subfun(int n, char (*subargs)[5])  
  4. {  
  5.     int i;  
  6.     for (i = 0; i < n; i++) {  
  7.         printf("subargs[%d] = %s\n", i, subargs[i]);  
  8.     }  
  9. }  
  10.   
  11. void main()  
  12. {  
  13.     char args[][5] = {"abc""cde""ghi"};  
  14.     subfun(3, args);  
  15. }  

方法三:形参为指针的指针

此方法实参必须为指针,而不能为数组名

举例

[cpp] view plaincopy
  1. #include <stdio.h>  
  2.   
  3. void subfun(int n, char **subargs)  
  4. {  
  5.     int i;   
  6.     for (i = 0; i < n; i++) {  
  7.         printf("subargs[%d] = %s\n", i, subargs[i]);  
  8.     }  
  9. }  
  10.   
  11. void main()  
  12. {  
  13.     char *a[3];  
  14.     char args[][5] = {"abc""def""ghi"};  
  15.     a[0] = args[0];  //equals with a[0] = &args[0][0];  
  16.     a[1] = args[1];  
  17.     a[2] = args[2];  
  18.     subfun(3, a);  //若此处为subfun(3, args);则会编译出错  
  19. }  

上述代码等价于下面代码。当然我们这里只是讨论的二维数组传参问题,下面代码只起扩展作用。

[cpp] view plaincopy
  1. #include <stdio.h>  
  2.   
  3. void subfun(int n, char **subargs)  
  4. {  
  5.     int i;   
  6.     for (i = 0; i < n; i++) {  
  7.         printf("subargs[%d] = %s\n", i, subargs[i]);  
  8.     }  
  9. }  
  10.   
  11. void main()  
  12. {  
  13.     char *args[] = {"abc""def""ghi"};//equals with char *args[3] = {"abc", "def", "ghi"};  
  14.     subfun(3, args);  
  15. }  

------------------------------------------------------------------------------------------------------------------------

方法四:形参为指针+数组的行+数组的列

#include <stdio.h>#include <stdlib.h>void test(double *p,const int m,const int n){for(int i=0;i<m;i++)for(int j=0;j<n;j++)printf("%f, \n",p[i*m+j]);}int main(int argc, char *argv[]){double a[2][2]={{1,2},{3,4}};test((double*)a,2,2);return 0;}

但不能如下使用:原因是double** 在堆里new出来的地址并不一定是连续的,而p[i*m+j]是在访问连续地址。

#include <stdio.h>#include <stdlib.h>void test(double *p,const int m,const int n){for(int i=0;i<m;i++)for(int j=0;j<n;j++)printf("%f, \n",p[i*m+j]);}int main(int argc, char *argv[]){//double a[2][2]={{1,2},{3,4}};double **a;a = new double*[2];for(int i =0;i<2;i++)a[i] = new double[2];//init for(int i =0;i<2;i++)for(int j =0;j<2;j++)a[i][j] = 1*i+j;for(int i=0;i<2;i++)for(int j=0;j<2;j++)printf("%f, \n",a[i][j]);test((double*)a[0],2,2);for(int i =0;i<2;i++)delete []a[i];delete [] a;return 0;}



0 0
原创粉丝点击