关闭

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

发表于:2013-5-07 09:12

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:linux_dsp_driver    来源:51Testing软件测试网采编

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

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

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

  举例:

#include <stdio.h>

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

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

  举例

#include <stdio.h>

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

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

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

  举例

#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[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);则会编译出错
}

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

#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[3] = {"abc", "def", "ghi"};
    subfun(3, args);
}

  本文转载自:http://blog.csdn.net/gqb666/article/details/8886687

《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号