this指针指向调用成员函数的对象,是编译器传递的隐式参数。它用于区分同名变量、实现链式调用,如返回*this支持连续操作。

在C++中,this指针是一个隐藏的指针,它指向调用成员函数的那个对象。每当一个类的成员函数被调用时,编译器会自动将该对象的地址作为隐式参数传递给这个函数,而this指针就是用来接收这个地址的。
1. this指针的本质
每个非静态成员函数的第一个隐式参数都是指向当前对象的指针,即this。它并不是存储在对象内存中的数据成员,而是由编译器在函数调用时自动生成的局部变量。
例如,定义一个简单的类:
class MyClass {public:
void setValue(int value) {
this->value = value;
}
private:
int value;
};
当调用 obj.setValue(10); 时,编译器实际上会将调用转换为:MyClass::setValue(&obj, 10)。其中,第一个参数就是this指针。
立即学习“C++免费学习笔记(深入)”;
2. this指针的用途
尽管this通常被隐式使用,但在某些场景下显式使用它非常有用:
- 区分同名变量:当形参与成员变量同名时,可用this->来明确访问成员。
- 支持链式调用:成员函数返回*this,可实现连续调用,如std::cout
- 判断两个对象是否相同:在成员函数中比较this与另一个对象的地址。
- 在运算符重载中保持语义一致:比如赋值操作符通常返回*this。
3. this指针的限制
this指针有一些关键特性需要注意:
- 只存在于非静态成员函数中,静态函数没有this指针,因为它们不依赖具体对象。
- this是const指针(类型为 MyClass* const),不能修改其指向,但可以修改它所指向的内容(除非函数被声明为const)。
- const成员函数中,this的类型变为 const MyClass* const,表示不能通过this修改对象状态。
4. 编译器如何处理this
编译器在编译阶段会重写成员函数签名,把this作为第一个参数插入。原始代码看似没有参数,实际在底层有额外传参机制。这也解释了为什么非静态成员函数的大小计算不包含this——它不是对象的一部分,而是运行时的上下文。
同时,这也是为什么不同对象调用同一个成员函数却能操作各自的数据:每个调用传入的this不同,访问的成员变量地址也就不同。
基本上就这些。this指针虽小,却是理解C++对象模型的关键一环。它连接了函数与实例,让成员函数“知道”自己在为谁服务。不复杂但容易忽略。










