C/C++中求数组长度的方法数组作为函数参数时退化为指针

2024-04-18 12:38

本文主要是介绍C/C++中求数组长度的方法数组作为函数参数时退化为指针,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.c/c++中求数组长度的方法

(1) c语言中一般是用宏定义:

#define ARR_LEN(array, length){ length =  sizeof(array) / sizeof(array[0]); }

使用的时候先声明一个length变量,再带入ARR_LEN(array, length);即可获得

(2) c++中可以用模板函数:

template <typename T>int getArrayLen(T &array){return sizeof(array) / sizeof(array[0]);}

比如:

string arr[]={"yruc", "opb", "dfa", "1234", "wangli"};int len=getArrayLen(arr);  //调用模板函数,获得len的值为5

2.但是有个要注意的重大问题:千万不要把已经退化成了指针的参数传入上诉模板函数中!但可以直接传入!,因为数组作为函数参数传入时退化为指针

比如,下面是一个错误示范:

#include<iostream>
#include<cstdlib>
#include<time.h>
using namespace std;
//求数组长度的模板函数
template<typename T>
int getArryLen(T& arr) {return (sizeof(arr) / sizeof(arr[0]));
}
//打印函数
void display(int arr[]) {int len = getArryLen(arr);//在这儿调用了模板函数,但是arr已经退化成了指针,而不是作为数组对象处理,所以不会得到想要的结果cout << "len=" << len << ",  sizeof(arr)=" << sizeof(arr) << endl;
}
int main() {//创建数组int arrNum[] = { 1,2,3};//这儿只是用int数组举例,任何类型的数组都会出现作为函数参数会退化为指针的问题//调用显示函数display(arrNum);system("pause");return 0;
}
//输出的结果却是:len=1,  sizeof(arr)=4.为什么会是这样的结果呢?

因为:当数组传入函数时,传入的是指针,指针仅指向数组头arr[0],不带有任何长度信息,所以就相当于sizeof(int *)/sizeof(arr[0])当然都是1了,因为两个都等于4,都是指向的arr[0]的指针,不带有任何长度信息,所以在自定义函数中传入数组时,还要把数组长度同时传入函数,这样才方便操作数组:比如数组排序啊,交换啊等等无论什么类型的数组都会出现上面的问题!!

那么这个问题怎么来解决呢,那就是不通过函数传参数!!而是直接调用getArrayLen(arr)模板函数即可!如果怕自己忘记,那么就用宏定义吧!

#include<iostream>
#include<cstdlib>
#include<time.h>
using namespace std;
//求数组长度的模板函数
template<typename T>
int getArryLen(T& arr) {return (sizeof(arr) / sizeof(arr[0]));
}int main() {//创建数组int arr[] = { 1,2,3};//调用模板函数获得数组长度int len=getArryLen(arr);//直接传入数组名,而不是把退化成了指针的数组名传入cout << "len=" << len << ",  sizeof(arr)=" << sizeof(arr) << endl;system("pause");return 0;
}
//输出的结果是:len=3,  sizeof(arr)=12.正常了!

 

这篇关于C/C++中求数组长度的方法数组作为函数参数时退化为指针的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/914807

相关文章

Java中流式并行操作parallelStream的原理和使用方法

《Java中流式并行操作parallelStream的原理和使用方法》本文详细介绍了Java中的并行流(parallelStream)的原理、正确使用方法以及在实际业务中的应用案例,并指出在使用并行流... 目录Java中流式并行操作parallelStream0. 问题的产生1. 什么是parallelS

MySQL数据库双机热备的配置方法详解

《MySQL数据库双机热备的配置方法详解》在企业级应用中,数据库的高可用性和数据的安全性是至关重要的,MySQL作为最流行的开源关系型数据库管理系统之一,提供了多种方式来实现高可用性,其中双机热备(M... 目录1. 环境准备1.1 安装mysql1.2 配置MySQL1.2.1 主服务器配置1.2.2 从

C++中unordered_set哈希集合的实现

《C++中unordered_set哈希集合的实现》std::unordered_set是C++标准库中的无序关联容器,基于哈希表实现,具有元素唯一性和无序性特点,本文就来详细的介绍一下unorder... 目录一、概述二、头文件与命名空间三、常用方法与示例1. 构造与析构2. 迭代器与遍历3. 容量相关4

C++中悬垂引用(Dangling Reference) 的实现

《C++中悬垂引用(DanglingReference)的实现》C++中的悬垂引用指引用绑定的对象被销毁后引用仍存在的情况,会导致访问无效内存,下面就来详细的介绍一下产生的原因以及如何避免,感兴趣... 目录悬垂引用的产生原因1. 引用绑定到局部变量,变量超出作用域后销毁2. 引用绑定到动态分配的对象,对象

Python版本信息获取方法详解与实战

《Python版本信息获取方法详解与实战》在Python开发中,获取Python版本号是调试、兼容性检查和版本控制的重要基础操作,本文详细介绍了如何使用sys和platform模块获取Python的主... 目录1. python版本号获取基础2. 使用sys模块获取版本信息2.1 sys模块概述2.1.1

Python实现字典转字符串的五种方法

《Python实现字典转字符串的五种方法》本文介绍了在Python中如何将字典数据结构转换为字符串格式的多种方法,首先可以通过内置的str()函数进行简单转换;其次利用ison.dumps()函数能够... 目录1、使用json模块的dumps方法:2、使用str方法:3、使用循环和字符串拼接:4、使用字符

Python版本与package版本兼容性检查方法总结

《Python版本与package版本兼容性检查方法总结》:本文主要介绍Python版本与package版本兼容性检查方法的相关资料,文中提供四种检查方法,分别是pip查询、conda管理、PyP... 目录引言为什么会出现兼容性问题方法一:用 pip 官方命令查询可用版本方法二:conda 管理包环境方法

Linux云服务器手动配置DNS的方法步骤

《Linux云服务器手动配置DNS的方法步骤》在Linux云服务器上手动配置DNS(域名系统)是确保服务器能够正常解析域名的重要步骤,以下是详细的配置方法,包括系统文件的修改和常见问题的解决方案,需要... 目录1. 为什么需要手动配置 DNS?2. 手动配置 DNS 的方法方法 1:修改 /etc/res

JavaScript对象转数组的三种方法实现

《JavaScript对象转数组的三种方法实现》本文介绍了在JavaScript中将对象转换为数组的三种实用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友... 目录方法1:使用Object.keys()和Array.map()方法2:使用Object.entr

SpringBoot中ResponseEntity的使用方法举例详解

《SpringBoot中ResponseEntity的使用方法举例详解》ResponseEntity是Spring的一个用于表示HTTP响应的全功能对象,它可以包含响应的状态码、头信息及响应体内容,下... 目录一、ResponseEntity概述基本特点:二、ResponseEntity的基本用法1. 创