C++ this 指针

在 C++ 中,每一个对象都能通过 this 指针来访问自己的地址this 指针是所有成员函数的隐含参数。因此,在成员函数内部,它可以用来指向调用对象。

1. C++ Primer Page 258

引入 this: 是 C++ 中的一个关键字,也是一个 const 指针,它指向当前对象,通过它可以访问当前对象的所有成员。

当我们调用成员函数时,实际上是替某个对象调用它。

成员函数通过一个名为 this 的额外隐式参数来访问调用它的那个对象,当我们调用一个成员函数时,用请求该函数的对象地址初始化 this。例如,如果调用 total.isbn()则编译器负责把 total 的地址传递给 isbn 的隐式形参 this,可以等价地认为编译器将该调用重写成了以下形式:

//伪代码,用于说明调用成员函数的实际执行过程
Sales_data::isbn(&total)

其中,调用 Sales_data 的 isbn 成员时传入了 total 的地址。

在成员函数内部,我们可以直接使用调用该函数的对象的成员,而无须通过成员访问运算符来做到这一点,因为 this 所指的正是这个对象。任何对类成员的直接访问都被看作是对 this 的隐式引用,也就是说,当 isbn 使用 bookNo 时,它隐式地使用 this 指向的成员,就像我们书写了 this->bookNo 一样。

对于我们来说,this 形参是隐式定义的。实际上,任何自定义名为 this 的参数或变量的行为都是非法的。我们可以在成员函数体内部使用 this,因此尽管没有必要,我们还是能把 isbn 定义成如下形式:

std::string isbn() const { return this->bookNo; }

因为 this 的目的总是指向“这个”对象,所以 this 是一个常量指针(参见2.4.2节,第56页),我们不允许改变 this 中保存的地址。
#include
using namespace std;

class Box{
public:
Box(){;}
~Box(){;}
Box* get_address() //得到this的地址
{
return this;
}
};

int main(){

Box box1;
Box box2;
// Box* 定义指针p接受对象box的get_address()成员函数的返回值,并打印

Box* p = box1.get_address();  
cout << p << endl;

p = box2.get_address();
cout << p << endl; 

return 0;

}

this 指针的类型可理解为 Box*。

此时得到两个地址分别为 box1 和 box2 对象的地址。

2. 友元函数没有 this 指针,因为友元不是类的成员。只有成员函数才有 this 指针

下面的实例有助于更好地理解 this 指针的概念:

#include <iostream>
 
using namespace std;
 
class Box
{
   public:
      // 构造函数定义
      Box(double l=2.0, double b=2.0, double h=2.0)
      {
         cout <<"Constructor called." << endl;
         length = l;
         breadth = b;
         height = h;
      }
      double Volume()
      {
         return length * breadth * height;
      }
      int compare(Box box)
      {
         return this->Volume() > box.Volume();
      }
   private:
      double length;     // Length of a box
      double breadth;    // Breadth of a box
      double height;     // Height of a box
};
 
int main(void)
{
   Box Box1(3.3, 1.2, 1.5);    // Declare box1
   Box Box2(8.5, 6.0, 2.0);    // Declare box2
 
   if(Box1.compare(Box2))
   {
      cout << "Box2 is smaller than Box1" <<endl;
   }
   else
   {
      cout << "Box2 is equal to or larger than Box1" <<endl;
   }
   return 0;
}

当上面的代码被编译和执行时,它会产生下列结果:

Constructor called.
Constructor called.
Box2 is equal to or larger than Box1
### C++ 中 `this` 指针的概念 在 C++ 编程语言中,`this` 是一个特殊的指针变量,在类的非静态成员函数内部自动存在。它指向当前正在被操作的对象实例[^1]。通过使用 `this` 指针,可以访问对象的数据成员以及成员函数。 #### 为什么需要 `this` 指针? 当在一个类的方法中定义了一个局部变量或者参数名与数据成员同名时,可能会发生命名冲突。此时可以通过 `this->` 来区分它们,其中 `this` 明确表示的是当前对象的数据成员[^2]。 --- ### `this` 指针的主要用途 以下是几种常见的场景下 `this` 的应用方式: #### 1. 解决名称冲突 如果某个方法接收的参数名字与其所属类中的成员变量相同,则可以用 `this` 指向实际的成员变量来消除歧义。 ```cpp #include <iostream> using namespace std; class Person { private: string name; public: void setName(string name) { this->name = name; // 使用 this 区分成员变量和形参 } void getName() const { cout << "Name is: " << name << endl; } }; int main(){ Person p; p.setName("Alice"); p.getName(); return 0; } ``` 上述例子展示了如何利用 `this` 避免因重名而产生的混乱情况。 #### 2. 返回当前对象本身 返回 *current object* 可用于链式调用(chaining),即连续执行多个操作于同一个对象之上而不需重复指定目标实体。 ```cpp class Counter{ private: int count; public: Counter():count(0){} Counter& increment(){ ++count; return *this; // 返回自身的引用以便支持连贯调用 } void displayCount()const{ cout<<"Current Count:"<<count<<endl; } }; // 测试部分省略... ``` 这里展示了一种模式——允许像这样写代码:`counter.increment().increment()`[^3]。 #### 3. 调用其他成员函数 有时候可能希望从某成员函数内部去触发另一个成员函数的动作;这时就可以借助 `this` 实现这一点。 ```cpp void bar() { std::cout << "Inside bar()" << std::endl; this->foo(); // 利用 this 呼叫另一项功能 } ``` 此片段取自先前提供的资料说明了怎样借由 `this` 执行额外的功能呼叫。 #### 4. 动态分配内存给对象副本 另外一种常见情形是在构造器里复制传入的对象属性值到新建立出来的个体之中,这时候也可以运用 `this`. ```cpp Person(const Person &other){ *(this)= other;// 将 another 对象的内容赋值给自己 } ``` 注意这里的语法结构意味着把右侧表达式的全部字段逐一对应拷贝至左侧所代表的新建体当中[^4]。 --- ### 总结注意事项 尽管 `this` 提供了许多便利之处,但也有一些地方值得特别留意: - 它仅存在于非静态成员函数之内; - 不可手动修改其地址值; - 当涉及多线程环境下的共享资源管理时要格外小心同步问题等等。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大江东去浪淘尽千古风流人物

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值