c++数组传参

一维数组,有两种传递方法,一种是function(int a[]); 另一种是function(int *a)。两种都是传入地址,因此在函数中对该数组做的操作,会改变原来的数组值。

#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std;

void addOne(int *p)
{


    for(int i=0;i<10;i++)
    {
        p[i]=i+3;
    }

}
int main()
{
    int a[100];
    for(int i=0;i<10;i++)
    {
        a[i]=i+1;
    }
   // cout<<sizeof(a)/sizeof(int);
    addOne(a);//将地址传入,在函数中的改变,就是对数组a 的改变
    for(int j=0;j<10;j++)
    cout<<a[j]<<" ";
    return 0;
}



//结果是3 4 5 6 7 8 9 10 11 12

然后二维的传参。。形式一种是function(int a[][n]);n要指定大小,同时传的也是地址,在函数中对数组的操作,就是对函数外的数组进行操作。

#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std;

void addOne(int p[][4])
{
    for(int i=0;i<3;i++)
    {
        for(int j=0;j<4;j++)
        {
            p[i][j]=p[i][j]+4;
        }
    }
}
int main()
{
    int a[][4]={0,1,2,3,4,5,6,7,8,9,10,11};
    addOne(a);//将地址传入,在函数中的改变,就是对数组a 的改变
    for(int i=0;i<3;i++)
    {
        for(int j=0;j<4;j++)
        {
           printf("%d ",a[i][j]);
        }
        printf("\n");
    }
    return 0;
}



/*
4 5 6 7
8 9 10 11
12 13 14 15


*/

如果我们采用这样:

void Func(int **array, int m, int n) ,

那么在实际的函数调用是,我们就要进行强制转换才可以用,我们可以这样调用void Func((int **)array, int m, int n);在函数调用时,要把数组形式写成指针形式如*((int*)array + n*i + j);直接写int array[i][j]会导致错误

#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std;

void addOne(int **p)
{
    for(int i=0;i<3;i++)
    {
        for(int j=0;j<4;j++)
        {
            *((int*)p + 4*i + j)=*((int*)p + 4*i + j)+4;//用指针的方式访问
        }
    }
}
int main()
{
    int a[][4]={0,1,2,3,4,5,6,7,8,9,10,11};
    //记得强转
    addOne((int**) a);//将地址传入,在函数中的改变,就是对数组a 的改变

    for(int i=0;i<3;i++)
    {
        for(int j=0;j<4;j++)
        {
           printf("%d ",a[i][j]);
        }
        printf("\n");
    }
    return 0;
}



猜你喜欢

转载自blog.csdn.net/pan_xi_yi/article/details/82918591