const修饰成员函数 && 取地址运算符的重载


const成员函数

  • 将const修饰的成员函数称之为const成员函数,const修饰成员函数放到成员函数参数列表的后⾯
  • const实际修饰该成员函数隐含的this指针指向的对象,表明在该成员函数中不能对类的任何成员进⾏修改。const 修饰Date类的Print成员函数,Print隐含的this指针由Date* const this 变为const Date* const this
class Date
{
public:
	Date(int year = 1, int month = 1, int day = 1)
	{
		_year = year;
		_month = month;
		_day = day;
	}
	 // void Print(const Date* const this) const
	 // 最后的const修饰的作用 默认自带的const
	void Pirnt() const
	{
		cout << _year << "/" << _month << "/" << _day << endl;
	}
	
private:
	int _year;
	int _month;
	int _day;
};
int main()
{
	Date d1(2024, 9, 30);
	d1.Pirnt(); // d1对象可读可写,调用Print函数是权限的缩小,变为只读,没毛病

	const Date d2(2024, 10, 1); //&d2 = const Date*
	d2.Pirnt();
	return 0;
}

我们看上面的实例,d1可以正常的调用Print函数,原因是:非const对象可以调用const成员函数你这是一种权限的缩小,上面的代码d2也可以调用成员函数,因为成员函数被const修饰,如果没有const修饰成员函数Print,d2再调用Print相当于是权限的放大,程序报错
总结一句什么情况下可以加const:一个类的成员函数不修改成员变量的情况下能加的就尽量加

取地址运算符重载

当我们想取一个自定义类型的地址该怎么办呢?直接用取地址操作符吗?按道理来讲,自定义类型的的操作符都需要进行重载,但是在C++中取地址操作的重载是一个默认的成员函数,所以可以直接取自定义类型的地址

  • 取地址运算符重载分为普通取地址运算符重载和const取地址运算符重载,⼀般这两个函数编译器⾃动⽣成的就可以够我们⽤了,不需要去显⽰实现。除⾮⼀些很特殊的场景,⽐如我们不想让别⼈取到当前类对象的地址,就可以⾃⼰实现⼀份,胡乱返回⼀个地址
class Date
{
public:
	Date(int year = 1, int month = 1, int day = 1)
	{
		_year = year;
		_month = month;
		_day = day;
	}

	Date* operator&()
	{
		return this;
		//return nullptr;
	}

	const Date* operator&() const
	{
		return this;
		//return nullptr;
		//return 0xff334400 //胡乱返回一个地址
	}

	 // void Print(const Date* const this) const
	void Pirnt() const
	{
		cout << _year << "/" << _month << "/" << _day << endl;
	}
private:
	int _year;
	int _month;
	int _day;
};
int main()
{
	Date d1(2024, 9, 30);
	const Date d2(2024, 10, 1);

	cout << &d1 << endl; // 调用第一个取地址的重载
	cout << &d2 << endl; // 调用第二个取地址的重载

	return 0;
}

取地址运算符重载作为一个人默认成员函数,编译器会默认生成两个版本,分别适用于有无const修饰


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值