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

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

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

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

  • 方法四:形参为指针+数组的行+数组的列
#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;
}

猜你喜欢

转载自blog.csdn.net/qq_40421919/article/details/81771710