设为首页 加入收藏

TOP

C/C++语言二维数组的传参方法
2013-05-14 09:21:52 来源: 作者: 【 】 浏览:218
Tags:C/C 语言 二维数 方法

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

  方法一:形参为二维数组并给定第二维长度

  此方法是最简单最直观的方法,形参与实参一样,容易理解。

  举例:

  #include <stdio.h>

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

  subfun(3, args);

  }

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

  举例

  #include <stdio.h>

  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", "cde", "ghi"};

  subfun(3, args);

  }

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

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

  举例

  #include <stdio.h>

  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 ;

  char args[] = {"abc", "def", "ghi"};

  a[0] = args[0];  //equals with a[0] = &args[0][0];

  a = args ;

  a = args ;

  subfun(3, a);  //若此处为subfun(3, args);则会编译出错

  }

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

  #include <stdio.h>

  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 = {"abc", "def", "ghi"};

  subfun(3, args);

  }

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇set和multiset的内部结构 下一篇C/C++如何获取系统时间

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: