C++函数传递数组方法及原理刨析

当数组作为函数形参的时候,正确的写法如下:

cpp 复制代码
//推荐写法
int printfArray(int a[], int num)
{
	int i = 0;
	for (i=0; i<num; i++)
	{
		std::cout<<a[i]<<std::endl;
	}
	return 0;
}

//不推荐写法
int printfArray(int* a, int num)
{
	int i = 0;
	for (i=0; i<num; i++)
	{
		std::cout<<a[i]<<std::endl;
	}
	return 0;
}

int main(int argc, char **argv)
{
    int a[10];
    printfArray(a,10);
    return 0;
}

上面两种写法都是正确的,之所以推荐用第一种写法,因为可读性更好一些,别人一眼就知道参数a是一个数组,而第二种写法不能直接看出a这个参数的意义。

有的同学就有疑问了,为啥两种写法都可以呢?

因为数组名字本身就是一个指针,它是一个指针常量,指向的地址不变。

比如定义了一个数组变量,编译器就会在内存中划分了一块地址空间给它,数组名这个指针常量就指向了这块内存空间的首地址,而数组首元素就存在这段内存空间的首地址处,即这段内存空间的首地址跟数组首元素的内存地址是一样的。

c++在这里插入代码片 复制代码
// c/c++编译器 会做优化,技术推演如下
int a[10]  --->int a[] ---->int *a

欢迎大家关注我的公众号,获取c++编程最新文章

相关推荐
To_OC3 小时前
LC 49 字母异位词分组:想到哈希表很简单,选对 key 才是精髓
javascript·算法·leetcode
用户938515635078 小时前
从 O(n²) 到 O(nlogn):一文读懂快速排序的“快”与“妙”
javascript·算法
To_OC9 小时前
手写快排次次翻车?别死背快排模板了,这才是面试官想听的底层逻辑
javascript·算法·排序算法
饼干哥哥9 小时前
Reddit VOC调研太慢?搭一个AI专家团队半小时洞察任何品类|以猫用饮水机为例
人工智能·算法·ai编程
地平线开发者11 小时前
Transformer模型部署之性能优化指南
算法
地平线开发者11 小时前
人在途中:从“编译失败”到“模型可落地”——CUDA 自定义算子
算法·自动驾驶
半个落月14 小时前
从递归到快速排序:用 JavaScript 把分治思想讲明白
javascript·算法·面试
小月土星15 小时前
JavaScript 快速排序:从 pivot、双指针到分治思想
javascript·算法·面试
小月土星15 小时前
JavaScript 递归入门:从 1 到 n 求和,再到数组扁平化
javascript·算法·面试