目录
- 一,const成员
- 二,取地址及const取地址操作符重载
一,const成员
将const修饰的“成员函数”称之为const成员函数,const修饰类成员函数,实际修饰该成员函数隐含的this指针,表明在该成员函数中不能对类的任何成员进行修改。
使用方式:规定在函数后面加 const。
看看下面的几段代码:
代码1:对象d1是const类型,Print函数后面没有const,运行结果报错。
class Date
{
public:
Date(int year, int month, int day)
{
_year = year;
_month = month;
_day = day;
}
//d1.Print(&d1); d1对象类型是 const Date* 只读
void Print() //Date* const this 可读可写 权限放大了
{
cout << _year << "-" << _month << "-" << _day << endl;
}
private:
int _year;
int _month;
int _day;
};
int main()
{
//d1是const对象,d1对象类型是const Date*
const Date d1(2024, 4, 14);
d1.Print();
return 0;
}
代码2:对象d1是const类型,在 Print 函数后加了const,正常运行。
class Date
{
public:
Date(int year, int month, int day)
{
_year = year;
_month = month;
_day = day;
}
//d1.Print(&d1); d1对象类型是 const Date* 只读
//const Date* const this,const修饰*this,本质改变this的类型
void Print() const
{
cout << _year << "-" << _month << "-" << _day << endl;
}
private:
int _year;
int _month;
int _day;
};
int main()
{
const Date d1(2024, 4, 25);
//d1是const对象,d1对象类型是 const Date*
d1.Print();
return 0;
}
代码3:对象d2不是const类型,在 Print 函数后加了const,正常运行。
class Date
{
public:
Date(int year, int month, int day)
{
_year = year;
_month = month;
_day = day;
}
//d2.Print(&d2); d2对象类型是Date* const,可读可写
void Print() const
{
cout << _year << "-" << _month << "-" << _day << endl;
}
private:
int _year;
int _month;
int _day;
};
int main()
{
Date d2(2024, 4, 25);//d2是非const对象
d2.Print();//调用Print就是权限的缩小
return 0;
}
图解如下:
总结:const成员函数是具有优势的,因为不管是传递含const对象,还是传递不含const对象,成员函数都可以调用。所以当我们要使用的对象不发生改变时,即隐含的this的内容不改变,一般都用const成员函数。
二,取地址及const取地址操作符重载
取地址操作函数和加了const的取地址操作函数构成重载。正常情况取出的是this指针的地址。
这两个默认成员函数一般不用我们自己定义 ,编译器默认会生成。
使用如下:
class A
{
public:
A* operator&()
{
cout << "A* operator&()" << endl;
return this;
}
const A* operator&() const
{
cout << "const A* operator&() const" << endl;
return this;
}
private:
int _a = 1;
int _b = 2;
int _c = 3;
};
int main()
{
A aa1;
const A aa2;
cout << &aa1 << endl;
cout << &aa2 << endl;
return 0;
}
除非不想让该类型的对象被取地址,就可以自己定义,返回指定地址(如空地址或是假地址) 。