C++中函数的形参主要有两种类型: 非引用形参和引用形参, 对应两种不同的参数传递方式。
void f(int t);
void f(int &t);
非引用行参是实参的一个副本, 故对非引用形参的修改不会影响实参;
引用形参是实参的别名,故对引用形参的修改其实就是修改实参;
两者的主要区别是:
1. 非引用形参在函数调用时,有从实参copy 到形参的拷贝开销, 在拷贝一些比较大的类类型对象时, 性能会受到比较大的影响;
2. 非引用形参不能修改实参内容;
C++中继承了C 语言通过指针来间接修改实参的做法, 但指针形参属于一种特殊的非引用形参,也有拷贝指针副本的开销,以及不能修改指针本身内容的限制。
现代C++推荐的做法是尽量使用引用行参, 避免拷贝开销。同时在不需要修改实参时,通过指定const 引用形参来限制。
const 引用除了可以避免修改是实参, 还有一个好处是可以使用字面值和产生右值的表达式实参初始化,而使用非const 引用只能使用类型完全相同的非const对象初始化。
这是由于const 对象的初始化规则约束的, 可以使用非const 对象初始化const 类型, 而不能使用const 对象初始非const 类型。
void f(int t);
void f(int &t);
非引用行参是实参的一个副本, 故对非引用形参的修改不会影响实参;
引用形参是实参的别名,故对引用形参的修改其实就是修改实参;
两者的主要区别是:
1. 非引用形参在函数调用时,有从实参copy 到形参的拷贝开销, 在拷贝一些比较大的类类型对象时, 性能会受到比较大的影响;
2. 非引用形参不能修改实参内容;
C++中继承了C 语言通过指针来间接修改实参的做法, 但指针形参属于一种特殊的非引用形参,也有拷贝指针副本的开销,以及不能修改指针本身内容的限制。
现代C++推荐的做法是尽量使用引用行参, 避免拷贝开销。同时在不需要修改实参时,通过指定const 引用形参来限制。
const 引用除了可以避免修改是实参, 还有一个好处是可以使用字面值和产生右值的表达式实参初始化,而使用非const 引用只能使用类型完全相同的非const对象初始化。
这是由于const 对象的初始化规则约束的, 可以使用非const 对象初始化const 类型, 而不能使用const 对象初始非const 类型。