const 和non-const成员函数转化

问题背景:这是针对同一个类的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;
}


版权声明:本文为TYtrack原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。