C++中的常引用(const reference)指的是被const修饰的引用类型,它绑定到一个对象后,无法通过该引用修改所引用对象的值,同时常引用可以绑定到临时对象、字面量等右值,这是普通引用不具备的特性。

常引用的基本定义与语法
常引用的声明语法是在引用符号&前加上const关键字,格式为const 类型& 引用名 = 目标对象,和普通引用最大的区别是常引用不能修改目标对象的值。
下面通过代码示例对比普通引用和常引用的区别:
#include <iostream>
using namespace std;
int main() {
int num = 10;
// 普通引用,可以修改目标对象
int& normal_ref = num;
normal_ref = 20;
cout << "修改后num的值:" << num << endl; // 输出20
// 常引用,无法修改目标对象
const int& const_ref = num;
// const_ref = 30; // 这行代码会编译报错,常引用不能修改目标值
cout << "常引用指向的num值:" << const_ref << endl; // 输出20
return 0;
}
常引用和普通引用的核心差异
除了不能修改目标对象外,常引用还有一个普通引用没有的特性:可以绑定右值,比如字面量、临时对象、表达式的结果等。普通引用只能绑定左值,绑定右值会直接编译报错。
看下面的代码示例:
#include <iostream>
using namespace std;
int getValue() {
return 100; // 返回临时对象,属于右值
}
int main() {
// 普通引用绑定右值,编译报错
// int& ref1 = 10;
// int& ref2 = getValue();
// 常引用可以绑定右值
const int& ref3 = 10; // 绑定字面量
const int& ref4 = getValue(); // 绑定函数返回的临时对象
const int& ref5 = (num + 5); // 绑定表达式结果
cout << ref3 << "," << ref4 << "," << ref5 << endl; // 输出10,100,25
return 0;
}
为什么优先使用常引用
1. 避免不必要的拷贝,提升性能
当函数需要接收较大的对象作为参数时,如果使用值传递,会发生对象的拷贝构造,消耗额外的内存和时间。使用常引用传递参数,只需要传递对象的地址,不需要拷贝整个对象,同时还能保证对象不会被修改。
比如传递一个大的结构体或者字符串对象:
#include <iostream>
#include <string>
using namespace std;
// 值传递,会发生string的拷贝
void printStrByValue(string s) {
cout << s << endl;
}
// 常引用传递,无拷贝,且不会修改原字符串
void printStrByConstRef(const string& s) {
cout << s << endl;
}
int main() {
string long_str = "这是一个很长的测试字符串,用来演示拷贝的开销";
printStrByValue(long_str); // 会拷贝long_str的内容
printStrByConstRef(long_str); // 无拷贝,直接引用原对象
return 0;
}
2. 保护数据不被意外修改
如果函数内部不需要修改传入的参数,使用常引用可以明确告诉编译器和阅读代码的人,这个参数不会被修改,避免函数内部误操作修改了外部的对象,减少bug的产生。
3. 支持传递临时对象,提升代码灵活性
很多时候我们需要直接传递临时对象给函数,比如函数返回的结果、字面量拼接的字符串等,如果使用普通引用作为参数,这些场景都无法编译通过,而常引用可以完美支持,让代码写起来更灵活。
常引用的使用注意事项
- 常引用绑定对象后,不能通过引用修改对象,但可以通过其他方式修改原对象,此时常引用看到的值也会同步变化
- 常引用作为函数返回值时,不能返回局部变量的常引用,局部变量在函数结束后会被销毁,引用会变成悬垂引用
- 常引用可以和普通引用指向同一个对象,二者只是访问权限不同,普通引用可以修改对象,常引用不行
总的来说,常引用是C++中非常实用的特性,在不需要修改对象、尤其是传递大对象作为参数的场景下,优先使用常引用可以兼顾性能和代码安全性,是C++开发中的最佳实践之一。
C++const_reference常引用引用传递修改时间:2026-07-01 05:30:29