C++数组做参数

首先,看一下下面这段代码:

void changearr(int a[],int n)
{
    cout<<sizeof(a)<<endl;         // 输出4
}
int main()
{
    int a[10] = {2,78,100,88,12,55,45,0,1,2};

cout<<sizeof(a)<<endl;         // 输出40
    changearr(a,10);
    return 0;
}

在C++中,数组名就是指向数组首元素地址的指针,数组索引就是距离数组首元素地址的偏移量。

数组永远不会按值传递,它传递的是数组首元素的指针,即第0个元素的指针。

所以,数组做参数时,有以下两点需要明白的:

1. 在被调用函数内对参数数组的改变将被应用到数组实参上而不是本地拷贝上。

2. 数组长度不是参数类型的一部分,函数不知道传递给它的数组的实际长度,编译器也不知道,当编译器

对实参类型进行参数类型检查时,并不会检查数组的长度。

以下三个函数声明是等价的:

void change_arr(int a[]);
void change_arr(int* a);
void change_arr(int a[10]);

如果想让编译器检查数组的长度,你可以将数组参数声明为数组的引用:

void change_arr(int (&a)[10]);

附:

C++数组一个奇葩用法:

使用a[i]和i[a]都可以访问数组a的第i个元素!!!

时间: 2024-08-28 14:31:43

C++数组做参数的相关文章

C++ 中数组做参数的分析

C++ 中数组做参数的分析 1.数组降价问题? "数组引用"以避免"数组降阶",数组降阶是个讨厌的事,这在C语言中是个无法解决的问题,先看一段代码,了解什么是"数组降阶" 1 #include <IOSTREAM> 2 using namespace std; 3 4 void Test( char array[20] ) 5 { 6 cout << sizeof(array) << endl; // 输出 4

0709 C语言常见误区----------二维数组做参数

总结: 1.二维数组名是指向一位数组的指针,本例中,其类型为 int (*)[4],在传递的过程中丢失了第一维的信息,因此需要将第一维的信息传递给调用函数. 关于二维数组名代表的类型,可通过下面的例子看出. 1 /************************************************************************* 2 > File Name: test_2arr.c 3 > Author:Monica 4 > Mail:[email prot

[转]数组引用:C++ 数组做参数 深入分析

"数组引用"以避免"数组降阶"(本文曾贴于VCKBASE\C++论坛) 受[hpho]的一段模板函数的启发,特写此文,如有雷同,实在遗憾. 数组降阶是个讨厌的事,这在C语言中是个无法解决的问题,先看一段代码,了解什么是"数组降阶" #include <IOSTREAM> using namespace std; void Test( char array[20] ) {     cout << sizeof(array)

3.对象数组做参数

//学生类 public class Student { //属性 public String name;//姓名 public int score; //方法 public void showInfo(){ System.out.println(name+"的成绩是:"+score); } } public class ModifyScore { //修改学员成绩,少于60的提高2分 public void modifyScore(Student[] stus){ for(int i

c 数组做为形参时 该参数退化为指针

当数组做为函数的形参的时候,该参数退化为指针,并且是无法直接求得数组的大小. 传数组给一个函数,数组类型自动转换为指针类型,因而传的实际是地址. void func(int array[10]) void func(int array[]) void func(int *array) 所以以上三种函数声明完全等同. 实际情况是,数组做参数,完全无法按值传递.这是由C/C++函数的实现机制决定的. 通常计算数组大小的方式如下: int len = sizeof(arr)/sizeof(type)

编程题:用一组数组做函数参数来实现,输入两个数,输出其中最大数

#include<stdio.h> float max(float x,float y) { float z; if(x>y)z=x; else z=y; return z; } void main() { float a[2],c; scanf("%f,%f",&a[0],&a[1]); c=max(a[0],a[1]); printf("%f,%f,the max is %f\n",a[0],a[1],c); } 编程题:用一组

C++二维数组(指针)做参数

一.问题描述 使用C++编程过程中经常需要使用到二维数组,然而初级程序员在使用过程中经常会出错使程序崩溃.下面就二维指针的定义,初始化,以及二维指针做参数给出简单介绍. 1.二维数组的定义与初始化 在实际使用数组的时候往往开始不知道二维数组的行数和列数,因此程序需要根据用户输入动态定义二维数组的行和列.这里通过C++二级指针来实现,引入变量 int rowNum 行 数, int coluNum 列数, char **p 二维字符数组,这里假定二维字符数组中的字符只能为'0'和'1'. int

C语言 数组做函数参数不传数组个数的遍历方法

//数组做函数参数不传数组个数的遍历方法 #include<stdio.h> #include<stdlib.h> #include<string.h> void PrintfAK(char **pin){ int i = 0; //关键点:pin[i]!=NULL为终止条件 for (i = 0; pin[i]!=NULL; i++) { printf("%s\n", pin[i]); } } void main(){ //赋值数组最后一个元素是0

C语言 数组做函数参数退化为指针的技术推演

//数组做函数参数退化为指针的技术推演 #include<stdio.h> #include<stdlib.h> #include<string.h> //一维数组做函数参数退化为指针的技术推演 void printfA(char * strarr[3]); //计算机中,数组都是线性存储,二维数组元素也是一个个的排列的 //例如: 1,2,3,4,5,6,7,8,9 像这组数据 我们可以认为是一维数组 int a[9]={1,2,3,4,5,6,7,8,9}; //也