关于数组做函数参数的问题集合汇总

 更新时间:2013年10月21日 09:48:52   作者:  
本文是对关于数组做函数参数的问题进行了详细的汇总,需要的朋友可以过来参考下。希望对大家有所帮助

首先是数组元素作为函数的实参,这和直接用多个变量作为函数的实参在用法上没有什么差别。

作为例子的代码:

复制代码 代码如下:

#include<iostream>
using namespace std;
int main(){
 int max(int a,int b);
        int a[2],m;
        a[0]=1;
        a[1]=2;
 m=max(a[0],a[1]);
 cout<<m; 
 return 0; 
}
int max(int a,int b ){
 if(a<b)a=b;
 return a;
}

输出结果是:2

然后,是用数组名作为函数参数,数组名其实代表的是数组首个元素的指针。

复制代码 代码如下:

#include<iostream>
using namespace std;
int main(){
        void alter(int b[]);//b[]括号里面的数值可写可不写,其作用是使编译系统把它当作一维数组来处理
        int a[2];
        a[0]=1;
        a[1]=2;
 alter(a);
 cout<<a[0]<<"\n";
 cout<<a[1]<<"\n"; 
 return 0; 
}
void alter(int b[]){
 b[0]=3;
 b[1]=4;
}

输出结果是:

3

4

如果我们这样写:

复制代码 代码如下:

#include<iostream>
using namespace std;
int main(){
        void alter(int b[20]);//b[]括号里面的数值可写可不写,其作用是使编译系统把它当作一维数组来处理
        int a[2];
        a[0]=1;
        a[1]=2;
     alter(a);
        cout<<sizeof(a); 
 return 0; 
}
void alter(int b[20]){
 cout<<sizeof(b)<<endl;
}

输出结果:

4

8

为什么我们已经定义了a[2]并且还赋值了,传递到函数以后,大小就只有一个单位呢?

其实,我们定义b[ ]或者b[2]或则b[1]、b[20]、b[100],作用都相当于是 *b。编译器直接忽略了,括号里面的数值。

为了能够更高的说明,数组名作为实参实际上是传递的数组的首指针,可以再看一下这个例子:

复制代码 代码如下:

#include<iostream>
using namespace std;
int main(){
    void alter(int *b);
    int a[2];
    a[0]=1;
    a[1]=2;
 alter(a);
 cout<<a[0]<<"\n";
 cout<<a[1]<<"\n"; 
 return 0; 
}
void alter(int *b){
 *b=3;
 *(b+1)=4;
}

这个和上面的那个输出结果完全一样!

================================分割线==========================

接下来,总结一下,数组的引用相关问题

首先是一个普通变量作为数组中一个值的引用的例子:

复制代码 代码如下:

#include<iostream>
using namespace std;
int main(){
    int a[2];
    a[0]=1;
    a[1]=2;
    int &t=a[0];
    t=5;
 cout<<a[0]<<"\n"; 
 return 0; 
}

输出结果是:5

普通变量作为数组中一个值的引用时,在使用上和int &a=b;并没有什么区别。

我们很自然的想到,普通的变量可以作为数组元素的引用,那么数组元素可否作为其他元素的引用呢?

看下面的代码:

复制代码 代码如下:

#include<iostream>
using namespace std;
int main(){
   int a[2];
   int b=100;
   &a[0]=b;//这么做是不被允许的
   cout<<a[0]<<endl;
   return 0;
}

编译器报错了,提示我们这样做是不被允许的。

但是捏,一个数组整体可以作为另一个数组的引用:

复制代码 代码如下:

#include<iostream>
using namespace std;
int main(){
    int a[2];
 a[0]=1;
 a[1]=2;
    int (&b)[2]=a;
    b[0]=3;
    b[1]=4;
 cout<<a[0]<<endl;
    cout<<a[1]<<endl;
 return 0;  
}

复制代码 代码如下:

#include<iostream>
using namespace std;
int main(){
    int a[2];
 a[0]=1;
 a[1]=2;
    int (&b)[2]=a;
    b[0]=3;
    b[1]=4;
 cout<<a[0]<<endl;
    cout<<a[1]<<endl;
 return 0;  
}

因为数值中的元素是不可以其他变量的引用的额,所以需要用(&b)来说明,这是数组整体引用,然后还必须写清楚数组的大小,即:
复制代码 代码如下:

(int (&b)[2])

这个使用方法,也就引出了,数组作为函数的形参的使用方法。

我们再看数组作为函数的形参的时候应该是怎样的。

复制代码 代码如下:

#include<iostream>
using namespace std;
int main(){
 void sm(int (&b)[2]);
        int a[2];
 a[0]=1;
 a[1]=2;
 sm(a);
 cout<<a[0]<<endl;
        cout<<a[1]<<endl;
 return 0;  
}
 void sm(int (&b)[2]){
  b[0]=3;
  b[1]=4;
 }

输出结果是

3

4

复制代码 代码如下:

#include<iostream>
using namespace std;
int main(){
    int a[2];
 a[0]=1;
 a[1]=2;
    int (&b)[2]=a;
    b[0]=3;
    b[1]=4;
 cout<<a[0]<<endl;
    cout<<a[1]<<endl;
 return 0;  
}

相关文章

  • C语言数据(整数、浮点数)在内存中的存储

    C语言数据(整数、浮点数)在内存中的存储

    之前对c语言数据存储一直不太明白,最近仔细研究了一番,所以下面这篇文章主要给大家介绍了关于C语言数据(整数、浮点数)在内存中存储的相关资料,需要的朋友可以参考下
    2021-06-06
  • 基于C语言实现简易三子棋游戏

    基于C语言实现简易三子棋游戏

    这篇文章主要为大家详细介绍了基于C语言实现简易三子棋游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下<BR>
    2022-01-01
  • C语言数字图像处理之图像缩放

    C语言数字图像处理之图像缩放

    这篇文章主要为大家详细介绍了C语言数字图像处理之图像缩放,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-10-10
  • 详解C语言结构体,枚举,联合体的使用

    详解C语言结构体,枚举,联合体的使用

    这篇文章主要给大家介绍一下关于C语言中结构体、枚举、联合体的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考一下
    2022-07-07
  • 在C++中反射调用.NET的方法(一)

    在C++中反射调用.NET的方法(一)

    为什么要在C++中调用.NET呢?接下来通过本文给大家介绍在C++中反射调用.NET的方法(一),需要的朋友参考下吧
    2017-02-02
  • 内联函数inline与宏定义深入解析

    内联函数inline与宏定义深入解析

    类的内敛函数是一个真正的函数。使用内联函数inline可以完全取代表达式形式的宏定义
    2013-09-09
  • C语言 格式化读写文件详解

    C语言 格式化读写文件详解

    本文主要介绍C语言 格式化读写文件,这里提供了关于格式化读写文件的基本资料及实现示例代码,有兴趣的小伙伴可以参考下,以便理解学习
    2016-08-08
  • C语言 struct结构体超详细讲解

    C语言 struct结构体超详细讲解

    C语言中,结构体类型属于一种构造类型(其他的构造类型还有:数组类型,联合类型),下面这篇文章主要给大家介绍了关于C语言结构体(struct)的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2022-04-04
  • C++深度优先搜索的实现方法

    C++深度优先搜索的实现方法

    这篇文章主要介绍了C++深度优先搜索的实现方法,是数据结构中非常重要的一种算法,需要的朋友可以参考下
    2014-08-08
  • C++封装线程类的实现方法

    C++封装线程类的实现方法

    这篇文章主要介绍了C++封装线程类的实现方法,实例介绍了针对线程的创建、调用等方法的封装操作,需要的朋友可以参考下
    2014-10-10

最新评论