一、问题背景
本文是针对自己在《C++ primer》一书的学习中在this指针这一小节的一些疑问的提出,以及最终解决的过程,希望能为大家提供一些有用经验分享。
主要解决的疑问是:同一对象的不同成员函数之间是否是同一个this指针,以及不同类型成员函数中的this指针有何不同?
二、 预备知识背景
this
指针是隐含每一个非静态成员函数内的一种指针。this
指针不需要定义,直接使用即可。this
指针默认情况下是一个指针常量,即指针本身不可修改,指向的对象可以修改。
说明:
- 首先,
this
指针并不是存在整个类/结构体中,它只存在于成员函数内。 - 实例化一个对象后,它的所有的成员函数都有着相同地址的
this
指针,这个地址就是该对象的首地址,也是这个结构体的第一个成员的地址。 - 虽然同一个对象的所有成员函数的
this
的值是一样的,但是此this
对对象成员的操作权限有所不同。这也是本文的重点讲解对象。
三、this的不同操作权限
- 同一个对象中,所有的成员函数中的
this
指针的值都是一样的,即都指向此对象。 - 常量成员函数与非常量成员函数中的
this
对对象的操作权限不同- 常量成员函数中的
this
指针,只读对象,不能修改对象的成员属性。 - 非常量成员函数中的
this
指针,可读可写对象,可以通过其修改对象的成员属性。
- 常量成员函数中的
类比比较:
//类比,实例化一个对象
int i = 10;
//合法,类比非常量成员函数的this指针指向一个非常量对象
int * const p = &i;
//合法,类比常量成员函数的this指针指向一个常量对象
const int * const q = &i;
//合法,类比非常量函数可以通过this指针修改对象的属性
*p = 12;
/*非法,类比常量函数不能通过this指针修改对象属性,
指向常量的指针不允许通过该指针对指向的对象的值进行修改,
但是并没有规定不能通过其他的方式进行修改,例如*p = 12。
其中p,q存放的是同一个对象i的地址,但是他们对对象i的操作权限有区别。*/
*q = 12;
struct Sales_data {
//1. 非常量成员函数
Sales_data* combine()
{
/*this 相当于上面的int * const p
(*this).revenue相当于上面的*p = 12;*/
(*this).revenue = 12;//合法
}
//2. 常量成员函数
Sales_data* isbn() const
{
/*this 相当于上面的const int * const q
(*this).revenue相当于上面的*q = 12;*/
(*this).revenue = 12;//非法
}
string bookNo;
unsigned units_sold = 0;
double revenue = 0.0;
};
void test1()
{
/*实例化一个常量对象*/
const Sales_data t;
}
int main(void)
{
test1();
}
四、总结
- this指针是在对象的非静态成员函数中才有效的,并不是整个类体中都存在。
- 默认情况下,
this
指针是一个指针常量,即指针的值不变,指针所指的内容可以改变。 - 常量成员函数中,
this
指针是一个指向常量的指针常量,即指针的值不变,指针指向的内容也不能变。(所谓的指向的内容不能变,只是不能通过该指针进行所指对象内容的修改) - 常量和非常量成员函数中的this指针所指向的对象是相同的,但是
this
指针本身的操作权限有所不同,这并不矛盾。