如何正确实现数组的函数传参(值传递/用指针进行地址传递)(C++实现)

您所在的位置:网站首页 返回数组类型的方法包括什么 如何正确实现数组的函数传参(值传递/用指针进行地址传递)(C++实现)

如何正确实现数组的函数传参(值传递/用指针进行地址传递)(C++实现)

2024-07-15 16:50| 来源: 网络整理| 查看: 265

 

目录

数组传参的传递方式有两种:

 值传递

值传递的例外:

原因:

数组传参时发生了“降维”,实际上传入的是该数组首元素的指针

地址传递

C++中主要有两种能实现地址传递的方法:

实现一些功能时,我们经常要把数组传进函数中进行操作。

数组传参的传递方式有两种:

值传递

地址传递

 值传递 值传递的例外:

        通常,对一般变量的值传递,函数会拷贝一个与实参的值相同的临时变量来使用,因此,在函数内部改变该变量并不会真正改变原变量的实际值。

        但是,对数组来说,通过值传递的函数,也能改变原数组的实际值。

// 值传递 void test(int arr[]); 原因: 数组传参时发生了“降维”,实际上传入的是该数组首元素的指针

         ->避免拷贝完整数组带来的低效率

参数传参仍然为值传递,只不过拷贝的是数组首元素地址的临时指针

因此,对于这种 数组通过“值传递”传参的函数,函数内部对数组元素的改变是真实存在的

另外:参数中的[]内可以省略数组具体大小的原因是,实际传参为数组首元素的指针,与数组实际大小并无关,因此此处[]内写了跟没写没有区别,只要不要写



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3