类的成员函数声明中常常见到const的身影,其作用是什么?有什么含义?这个const是用来修饰this指针的,你也可以理解为修饰成员函数的,是一个常量成员函数。
一、默认情况,this 指针绑定的对象是不变的对象如果不可以修改,this
指针就会失效。如下面的A类:
class A
{
public:
void fun(){this->a=333;}//this指针可以省略,隐藏
private:
int a=44;
//const A * this;方便理解
};
int main()
{
A a;
const A aa;
a.fun();
aa.fun();//error,this指针不能操作const对象,因为其默认属性为top-level const
}
this
指针巧妙之处在于,类中的所有方法都不需要显式书写A * const this
,在方法内部也不需要写this->xxx
,隐藏了许多不必要书写。this
指针要求对象是可以改变的,这是否意味着我们只能对一个非常量调用其定义的方法?是否可以修改this
的属性?当然可以!
在成员函数()
后增加const用于改变this的默认属性,这个const出现意味着,这个this的属性既是top-level 又是low-level的,const * const this
。但是这个this指针变成了只读指针,你不能对对象进行任何写操作。
class A
{
public:
void fun() cout
关注
打赏
最近更新
- 深拷贝和浅拷贝的区别(重点)
- 【Vue】走进Vue框架世界
- 【云服务器】项目部署—搭建网站—vue电商后台管理系统
- 【React介绍】 一文带你深入React
- 【React】React组件实例的三大属性之state,props,refs(你学废了吗)
- 【脚手架VueCLI】从零开始,创建一个VUE项目
- 【React】深入理解React组件生命周期----图文详解(含代码)
- 【React】DOM的Diffing算法是什么?以及DOM中key的作用----经典面试题
- 【React】1_使用React脚手架创建项目步骤--------详解(含项目结构说明)
- 【React】2_如何使用react脚手架写一个简单的页面?