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

在C++中,数组不能以值的形式完整传递给函数,因为数组名在作为参数时会退化为指针。理解这一点是掌握C++数组参数传递的关键。函数接收到的并不是数组的副本,而是指向首元素的指针。因此,常见的传递方式虽然写法不同,本质都与指针密切相关。
使用指针形参
当把数组传递给函数时,实际上传递的是数组首元素的地址。因此,可以用指针来接收:
示例代码:
立即学习“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++免费学习笔记(深入)”;
template
void printArray(int (&arr)[N]) {
for (int i = 0; i std::cout }
std::cout }
这里int (&arr)[N]表示对大小为N的整型数组的引用。模板参数N由编译器自动推导。调用时无需传大小:
int data[] = {1, 2, 3};
printArray(data); // N自动推导为3
这种方式安全且能保留维度信息,适合固定大小数组的场景。
推荐使用标准容器或span(现代C++)
对于更安全和灵活的设计,建议使用std::vector或C++20的std::span:
使用std::vector:
void printVector(const std::vector& vec) {
for (int val : vec) {
std::cout }
std::cout }
使用std::span(C++20):
#include
void printSpan(std::span span) {
for (int val : span) {
std::cout }
std::cout }
这些现代方式不仅语义清晰,还能自动管理大小信息,减少出错可能。
基本上就这些。根据使用场景选择合适的方式:传统指针用于兼容旧代码,引用数组用于固定大小传递,而vector或span更适合新项目中的灵活性与安全性需求。关键是要清楚数组传参会退化为指针这一核心机制。
以上就是C++如何传递数组给一个函数_C++数组参数传递方式解析的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1483598.html
微信扫一扫
支付宝扫一扫