C++ 何时使用引用参数(一些指导原则)
2016-03-08 19:44
274 查看
转自:http://blog.csdn.net/rushkid02/article/details/7917131
使用引用参数的原因:
1. 程序员能够修改调用函数中的数据对象
2. 通过传递引用而不是整个数据对象,可以提高程序的运行速度。
当数据对象较大时(如结构和类对象),第二个原因最重要,这些也是使用指针参数的原因。这是有道理的,因为引用参数实际上是基于指针的代码的另一个接口。
那么什么时候使用引用、什么时候使用指针?什么时候又应该按值传递呢?下面是一些指导原则:
对于使用传递值而不做修改的函数:
1. 如果数据对象较小,如内置数据类型或者小型结构,则按值传递。
2. 如果数据对象是数组,则使用指针,因为这是唯一的选择,并将指针声明为指向const的指针。
3. 如果数据对象是较大的结构,则使用const指针或const引用,以提高运行效率。这样可以节省复制结构所需的时间和空间。
4. 如果数据对象是类对象,则使用const引用。类设计的语义常常要求使用引用,这是C++增加引用特性的主要原因。因此,传递类对象参数的标准方式是按引用传递。
对于修改调用函数中数据的函数:
1. 如果数据对象是内置数据类型,则是用指针。如果看到诸如fixit(&x)这样的代码(其中x是int型),则很明显,该函数将修改x。
2. 如果数据对象是数组,则只能使用指针。
3. 如果数据对象是结构,则使用引用或指针。
4. 如果数据对象是类对象,则使用引用。
使用引用参数的原因:
1. 程序员能够修改调用函数中的数据对象
2. 通过传递引用而不是整个数据对象,可以提高程序的运行速度。
当数据对象较大时(如结构和类对象),第二个原因最重要,这些也是使用指针参数的原因。这是有道理的,因为引用参数实际上是基于指针的代码的另一个接口。
那么什么时候使用引用、什么时候使用指针?什么时候又应该按值传递呢?下面是一些指导原则:
对于使用传递值而不做修改的函数:
1. 如果数据对象较小,如内置数据类型或者小型结构,则按值传递。
2. 如果数据对象是数组,则使用指针,因为这是唯一的选择,并将指针声明为指向const的指针。
3. 如果数据对象是较大的结构,则使用const指针或const引用,以提高运行效率。这样可以节省复制结构所需的时间和空间。
4. 如果数据对象是类对象,则使用const引用。类设计的语义常常要求使用引用,这是C++增加引用特性的主要原因。因此,传递类对象参数的标准方式是按引用传递。
对于修改调用函数中数据的函数:
1. 如果数据对象是内置数据类型,则是用指针。如果看到诸如fixit(&x)这样的代码(其中x是int型),则很明显,该函数将修改x。
2. 如果数据对象是数组,则只能使用指针。
3. 如果数据对象是结构,则使用引用或指针。
4. 如果数据对象是类对象,则使用引用。
相关文章推荐
- 操作系统用C语言模拟进程基于优先级的调度程序
- C语言中参数的传递
- C++中的继承和组合区别使用
- C语言内存管理(内存池)
- c++输出浮点数
- C语言程序经过编译链接后形成二进制映像文件的组成
- iOSDay03C语言循环结构
- Cpp--new和delete的应用
- Cpp--类的组合
- 在eclipse中使用mingw开发c++
- c++ 一次读取文件全部内容
- C/C++面试常见的几个库函数详解(strcpy,memcpy,memset,atoi...)
- 多封装,少开放。强烈建议C++标准添加class之间的注入机制
- C++中vector容器的基本用法总结
- [逼死强迫症 - C&C++设计风格选择.1] : 命名规范
- C++第一次上机实验报告-1
- C语言获得数组长度的函数
- c++下可调对象作为参数的实现
- C++初始化列表
- 反转单链表