C++中数组作为参数传递时,是否能在传递过后求该数组的大小呢?
2013-11-23 16:41
316 查看
今天在写程序 时,发现如下代码运行有问题:
原来使用这种方法调用函数时,传入函数内的dest实际上是原dest的首地址,并不是dest这个数组,换句话说,传进去的是指向dest数组的指针,这样当然无法获得dest数组的正确大小。
当你定义一个数组的时候:
int a[] = {1, 2, 3}; // 实际上被编译为 int a[3] = {1,2,3}
数组名代表的是数组的地址。注意 —— 你绝对没有办法通过数组名动态获得数组的大小。当你丢失a的长度信息的时候,你永远不可能知道他的长度。
那么 sizeof 是怎么回事呢?他不是通过 a 的名字获得 a的大小了么? —— 大错特错!
关键字 sizeof 产生的是一个编译期常量(注1) 他的运作方式是这样的:
当你写:
sizeof a
实质是:
sizeof ( a的类型 )
而a的类型是什么呢?编译器察看 a的定义发现, 是 int [3]
就是说,这里 sizeof a 实质是:
sizeof ( int[3] )
完全等同于常量 12 (假定int为4字节)。
考虑一个函数
void func( int a[] );
// 写成 int a[3] 也不会有本质区别——也许你该试试写成 int (&a) [3] ?
C++规定,数组作为形参的时候,a代表数组首地址。
他的底层意义是: a 退化为了一个4字节的指针,没有任何变量表示数组的大小会“自动”被传递进来。
我们看看这个时候 sizeof a是什么:
sizeof( 函数形参的a[] ) = sizeof( int* const ) = 4 // 当然a[]不是合法的C++类型
因此,因此,此处的sizeof(dest)等同于上面的sizeof(a[])
所以,要在传递数组前,将该数组的长度算出来,然后一并作为参数传过来。
修改代码如下:
problem solved!
void multPacket(int dest[],int pid) { int member=sizeof(dest)/sizeof(int);//表示成員個數 cout<<sizeof(dest)<<endl; cout<<sizeof(int)<<endl; for(int i=0;i<member;i++) { cout<<"已經向第"<<dest[i]<<"個用戶發送報文"<<pid<<endl; } }通过输出结果发现,只能输出第一个元素 ,即dest[1] ,添加了两行输出代码后,发现sizeof(dest)竟然长度为4。
原来使用这种方法调用函数时,传入函数内的dest实际上是原dest的首地址,并不是dest这个数组,换句话说,传进去的是指向dest数组的指针,这样当然无法获得dest数组的正确大小。
当你定义一个数组的时候:
int a[] = {1, 2, 3}; // 实际上被编译为 int a[3] = {1,2,3}
数组名代表的是数组的地址。注意 —— 你绝对没有办法通过数组名动态获得数组的大小。当你丢失a的长度信息的时候,你永远不可能知道他的长度。
那么 sizeof 是怎么回事呢?他不是通过 a 的名字获得 a的大小了么? —— 大错特错!
关键字 sizeof 产生的是一个编译期常量(注1) 他的运作方式是这样的:
当你写:
sizeof a
实质是:
sizeof ( a的类型 )
而a的类型是什么呢?编译器察看 a的定义发现, 是 int [3]
就是说,这里 sizeof a 实质是:
sizeof ( int[3] )
完全等同于常量 12 (假定int为4字节)。
考虑一个函数
void func( int a[] );
// 写成 int a[3] 也不会有本质区别——也许你该试试写成 int (&a) [3] ?
C++规定,数组作为形参的时候,a代表数组首地址。
他的底层意义是: a 退化为了一个4字节的指针,没有任何变量表示数组的大小会“自动”被传递进来。
我们看看这个时候 sizeof a是什么:
sizeof( 函数形参的a[] ) = sizeof( int* const ) = 4 // 当然a[]不是合法的C++类型
因此,因此,此处的sizeof(dest)等同于上面的sizeof(a[])
所以,要在传递数组前,将该数组的长度算出来,然后一并作为参数传过来。
修改代码如下:
void multPacket(int dest[],int pid,int size)//pid表示报文号 size 表示dest的长度 { //int member=sizeof(dest)/sizeof(int);//表示成員個數 //cout<<sizeof(dest)<<endl; //cout<<sizeof(int)<<endl; for(int i=0;i<size;i++) { cout<<"已經向第"<<dest[i]<<"個用戶發送報文"<<pid<<endl; } }在调用函数之前,就将dest的size算出来,然后传进来就行了!
problem solved!
相关文章推荐
- c++ 二维动态数组初始化及作为参数传递
- 关于在C/C++语言中,函数如何返回数组,数组如何作为参数传递以及返回数组的函数该如何调用问题的总结
- C#调用c++的dll,结构体数组作为引用参数的传递方式
- c++中关于数组作为函数参数并传递数组元素个数的几种有效方法的讨论
- c++中关于数组作为函数参数并传递数组元素个数的几种有效方法的讨论
- C语言函数 数组是否可以作为值传递?
- 数组大小作为参数传递(通过模板数值参数)
- C/C++语法[02]---数组作为参数传递的方式
- c++传递数组大小的方式
- C++知识点补强之----数组作为参数传递
- c++中关于数组作为函数参数并传递数组元素个数的几种有效方法的讨论
- C++_new创建的数组作为参数传递
- C++_数组作为参数传递
- C语言中 数组作为函数形参传递相当于指针,在函数中不能得到数组长度,只能得到指针长度4
- c++学习连载-求数组大小
- net中 类、方法作为参数传递的写法整理。(通过反射实现)(即传递类、传递方法的实现)
- C++中多维数组传递参数
- js调用c/c++dll,用字符串/数组作为参数
- jQuery $.ajax传递数组的traditional参数传递必须true
- 在COM/DCOM中如何将数组作为函数返回的类型传递