C++使用引用的主要原因

原则部分内容参考于《C++Primer Plus 6》第八章

使用引用参数的主要原因有两个:
        1.能够修改调用函数中的数据对象,因为引用与原对象指向地址的同一个内容,引用可看作是别名。
        2.通过传递引用而不是整个数据对象,可以提高程序的运行速度,因为传值需要复制拷贝整个数据内容,而引用指向原来的数据内容,只是传递了一个别名。

当数据较大(结构或类对象),传递引用以提高程序运行速度显得很重要,在此情况下,合理使用指针参数同样可以提高运行速度。

那么何时使用引用;指针或按值来传递数据呢?相信很多朋友都会有类似的疑问。从书中得到一些指导原则,给大家分享:

一.对于使用传递的值而对传递的值不作修改的函数来说,有如下几个指导原则:

  1. 如果数据对象很小,如内置数据类型或小型结构,则按值传递。
  2. 如果数据对象是数组,则使用指针,因为这是唯一的选择,并将指针声明为指向const的指针。
  3. 如果数据对象是较大的结构,则使用const指针或const引用,以提高程序的效率。这样可以节省复制结构所需的时间和空间。
  4. 如果数据对象是类对象,则使用const引用。类设计的语义常常要求使用引用,这是C++新增这项特性的主要原因。因此,传递类对象参数的标准方式是按引用传递。

 二.对于需要修改调用函数中数据的函数来说:

  1. 如果数据对象是内置数据类型,则使用指针。如果看到诸如fixit(&x)这样的代码(其中x是int),则很明显,该函数将修改x。
  2. 如果数据对象是数组,则只能使用指针。
  3. 如果数据对象是结构,则使用引用或指针。
  4. 如果数据对象是类对象,则使用引用。
     

由上述可知,主要先查看自己需要使用的函数中是否需要修改传入参数,然后再看自己处理的数据大小,数据对象的类型是数组?结构?或对象?来判断使用情况。

需要注意,引用可看作一个对象的别名,引用与原对象都指向同一个地址或内存块中的唯一的一个数据,所以对引用的内容的更改,同时会更改原始的数据。 引用不用全部拷贝数据,所以在数据量大的情况比传值来讲更快。

 

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值