问题背景:这是针对同一个类的const对象和non-const对象来说的,由于一个const对象只能调用const成员函数,因此有的时候需要同时实现针对const对象和non-const对象的 const方法和non-const方法,大部分时候有着实质等价实现,可以使用non-const版本调用const版本避免代码重复,然后在non-const中再添加自己的内容。
什么是const成员函数,在参数列表后有const关键字的方法为const方法;
解决方案:使用static_cast<const T1>和const_cast<T2>来实现const和非const的切换,这里使用的是non_const调用const版本。
方案问题:为什么不用const调用非const,因为这就会违背const不改变其对象的逻辑,因为非const没有承诺不会改变内容
详细方案:先使用static_cast 将*this从原始类型转化为const类型,再调用函数,使用const_cast移除函数返回值的const性质
代码案例:
#include "iostream"
using namespace std;
class arr{
public:
int *a;
int size;
arr(int size_,int initc){
a=new int[size_];
size=size_;
for(int i=0;i<size_;i++)
*(a+i)=initc;
};
~arr(){
delete [] a;
a=nullptr;
size =0;
};
const int& operator[](int x) const{
if(x>=size)
{
throw -1;
}
return *(a+x);
};
int &operator[](int x){
return const_cast<int &>(static_cast<const arr &>(*this)[x]);
};
void print() const {
for(int i=0;i<size;i++)
cout <<*(a+i)<<" ";
cout <<endl;
};
};
int main(){
arr cc_val(3,10);
cc_val[1]=8;
cc_val.print();
const arr cc(3,10);
// error: assignment of read-only location ‘cc.arr::operator[](1)’
// cc[1]=8;
cc.print();
return 0;
}