C++二维数组传参

来源:互联网 发布:javascript编程艺术 编辑:程序博客网 时间:2024/06/08 06:11

C/C++语言将二维数组作为参数传递容易使人迷惑且易出错,本文将常用的几种方法列出,以方便用时查阅。


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

void subfun(int n, char subargs[][5])  {      int i;      for (i = 0; i < n; i++) {          printf("subargs[%d] = %s\n", i, subargs[i]);      }  }  void main()  {      char args[][5] = {"abc", "def", "ghi"};      subfun(3, args);  }  

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

void subfun(int n, char (*subargs)[5])  {      int i;      for (i = 0; i < n; i++) {          printf("subargs[%d] = %s\n", i, subargs[i]);      }  }  void main()  {      char args[][5] = {"abc", "cde", "ghi"};      subfun(3, args);  }  

方法三:形参为指针的指针
此方法实参必须为指针,而不能为数组名
举例

void subfun(int n, char **subargs)  {      int i;       for (i = 0; i < n; i++) {          printf("subargs[%d] = %s\n", i, subargs[i]);      }  }  void main()  {      char *a[3];      char args[][5] = {"abc", "def", "ghi"};      a[0] = args[0];  //equals with a[0] = &args[0][0];      a[1] = args[1];      a[2] = args[2];      subfun(3, a);  //若此处为subfun(3, args);则会编译出错  }  

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


void subfun(int n, char **subargs)  {      int i;       for (i = 0; i < n; i++) {          printf("subargs[%d] = %s\n", i, subargs[i]);      }  }  void main()  {      char *args[] = {"abc", "def", "ghi"};//equals with char *args[3] = {"abc", "def", "ghi"};      subfun(3, args);  }  

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


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;  }  

http://blog.csdn.net/deng_sai/article/details/48346091