数组传递时退化为指针,函数接收的是首元素地址。例如void printArray(int* arr, int size)通过指针访问数组元素,而非复制整个数组。

在C++中,数组不能以值的形式完整传递给函数,因为数组名在作为参数时会退化为指针。理解这一点是掌握C++数组参数传递的关键。函数接收到的并不是数组的副本,而是指向首元素的指针。因此,常见的传递方式虽然写法不同,本质都与指针密切相关。
使用指针形参
当把数组传递给函数时,实际上传递的是数组首元素的地址。因此,可以用指针来接收:示例代码:
本文档主要讲述的是Android_Intent详解;Intent 是一个将要执行的动作的抽象的描述,一般来说是作为参数来使用,由Intent来协助完成android各个组件之间的通讯。比如说调用startActivity()来启动一个activity,或者由broadcaseIntent()来传递给所有感兴趣的BroadcaseReceiver, 再或者由startService()/bindservice()来启动一个后台的service.所以可以看出来,intent主要是用来启动其他的activity
立即学习“C++免费学习笔记(深入)”;
// 函数声明void printArray(int* arr, int size) {
for (int i = 0; i std::cout }
std::cout }
// 调用
int data[] = {1, 2, 3, 4, 5};
printArray(data, 5); // data 自动转为 int*
这种方式最直接体现数组传参的本质——传地址。函数内部对arr的操作等同于对原数组操作。
使用数组形参语法(等价于指针)
C++允许使用数组语法声明形参,但这只是形式上的写法,编译器仍将其视为指针:示例代码:
立即学习“C++免费学习笔记(深入)”;
void printArray(int arr[], int size) {// 与 int* arr 完全相同
for (int i = 0; i std::cout }
std::cout }
尽管写成了int arr[],但这里的arr依然是指针类型,sizeof(arr)在函数内返回的是指针大小,而非整个数组大小。
使用引用传递保留数组大小信息
如果想让函数知道数组的实际大小,可以使用引用方式传递数组。这种方法能避免退化为指针:示例代码:
立即学习“C++免费学习笔记(深入)”;
templatevoid printArray(int (&arr)[N]) {
for (int i = 0; i std::cout }
std::cout }
这里int (&arr)[N]表示对大小为N的整型数组的引用。模板参数N由编译器自动推导。调用时无需传大小:
printArray(data); // N自动推导为3
这种方式安全且能保留维度信息,适合固定大小数组的场景。
推荐使用标准容器或span(现代C++)
对于更安全和灵活的设计,建议使用std::vector或C++20的std::span:使用std::vector:
void printVector(const std::vectorfor (int val : vec) {
std::cout }
std::cout }
使用std::span(C++20):
#includevoid printSpan(std::span
for (int val : span) {
std::cout }
std::cout }
这些现代方式不仅语义清晰,还能自动管理大小信息,减少出错可能。
基本上就这些。根据使用场景选择合适的方式:传统指针用于兼容旧代码,引用数组用于固定大小传递,而vector或span更适合新项目中的灵活性与安全性需求。关键是要清楚数组传参会退化为指针这一核心机制。









