指针是存储变量地址的独立变量,可重新赋值且可为空;引用是变量别名,必须初始化且不可改变指向。

指针和引用在C++中都能用来操作变量的内存地址,但它们在使用方式、特性和底层机制上有明显区别。理解这些差异对编写高效、安全的C++代码非常重要。
1. 定义与初始化
指针是一个变量,它存储另一个变量的地址。指针可以定义时不初始化,也可以指向空值(nullptr)。
int a = 10;int* ptr = &a; // 指针指向a的地址
int* ptr2 = nullptr; // 空指针
引用是某个变量的别名,必须在声明时初始化,且一旦绑定就不能再更改目标。
int a = 10;int& ref = a; // 引用必须初始化,ref是a的别名
2. 是否可改变指向
指针可以在程序运行过程中重新赋值,指向不同的变量。
立即学习“C++免费学习笔记(深入)”;
int a = 10, b = 20;int* ptr = &a;
ptr = &b; // 合法,指针可以改变指向
引用一旦初始化后,就不能再指向其他变量。
int a = 10, b = 20;int& ref = a;
ref = b; // 注意:这实际上是把b的值赋给a(ref仍是a的别名),不是改变引用的目标
3. 内存占用与地址
指针本身是一个独立的变量,占用内存(例如64位系统上通常8字节),有自己的地址。
cout
引用并不分配额外的内存空间,它只是原变量的别名,不占用独立存储(编译器通常通过指针实现,但对程序员透明)。
4. 可空性与安全性
指针可以为nullptr,表示不指向任何对象,因此使用前必须检查有效性,否则容易引发崩溃。
if (ptr != nullptr) {cout }
引用不能为“空”,必须绑定到一个有效对象。但如果绑定的是临时或已销毁的对象(如返回局部变量的引用),会导致未定义行为。
5. 应用场景
指针常用于动态内存管理(new/delete)、数组操作、函数返回多个值、实现数据结构(链表、树等)。
引用常用于函数参数传递(避免拷贝)、函数返回值(返回对象本身)、运算符重载等需要简洁语法和高效访问的场合。
void swap(int& a, int& b) {int temp = a;
a = b;
b = temp;
}
基本上就这些。指针更灵活但需小心管理,引用更安全简洁但有使用限制。根据实际需求选择合适的方式。










