C++ 模板类=设计 or template class operator=

本文介绍了如何在C++模板类中设计并重载赋值运算符=,强调了不同类型的赋值操作可能涉及类型转换函数的使用。通过实例展示了模板类中创建临时对象、调用构造函数、赋值操作和析构的过程,并提供了经过测试的有效代码片段。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

设计一个模板类,某个成员变量是在调用的时候才能知道其具体类型。设计重载运算符=。

需要特别重视的是:
Vec<int>Vec<float> 是不同的类型,不同类型之间的赋值,会默认调用类型转换函数。


模板类

// undefied behavior for 0 > _len 
template<class _T>
class Vec{
public:
    Vec() : _len(0), _dat(NULL) {}
    Vec(const int32_t len) {
        _len = len;
        _dat = new _T[len];
    }
    Vec(const int32_t len, const _T &val) {
        _len = len;
        _dat = new _T[len];
        for (int32_t i = 0; i < _len; i++){
            _dat[i] = val;
        }
    }
    template<class CT>
    Vec(const Vec<CT> &obj){
        _len = obj.get_len();
        if (0!=_len){
            _dat = new _T[_len];
        }
        for (int32_t i = 0; i < _len; i++){
            _dat[i] = (_T)(obj.get_dat()[i]);
        }       
    }

    ~Vec(){
        if (_dat){
            delete[] _dat;  _dat = NULL;
        }
        _len = 0;
    }

public:
    Vec<_T>& operator=(const Vec<_T> &B){
        if (_dat){
            delete[] _dat;
        }
        _len = B._len;
        if (0!=_len){
            _dat = new _T[B._len];
        }
        for (int i = 0; i < _len; i++){
            _dat[i] = B._dat[i];
        }
        return *this;
    }

public: // utilities
    template<class T>
    friend std::ostream& operator<<(std::ostream &output, Vec<T> &am);

    int32_t get_len() const{
        return _len;
    }
    _T* get_dat() const {
        return _dat;
    }
private:
    int32_t _len;
    _T* _dat;
};

template<class T>
std::ostream& operator<<(std::ostream &output, Vec<T> &am){
    output << am._dat << " : ";
    for (int32_t i = 0; i < am._len; i++){
        cout << am._dat[i] << " ";
    }
    return output;
}

测试

Vec<int16_t>  A(10, 2);
Vec<int32_t> B;
B = A; 
cout << A << endl;
cout << B << endl;

其中一次输出结果:

01409C88 : 2 2 2 2 2 2 2 2 2 2
0140BA18 : 2 2 2 2 2 2 2 2 2 2

B=A 首先 调用 Vec<int32_t>(A)构造一个临时的Vec<int32_t>的对象, 对应被调用的构造函数是Vec<int16_t>(const Vec<int16_t>&). 然后,以被构造的临时对象为右参数调用Vec<int32_t>& operator=(const Vec<int32_t>&). 最后,将临时构造的对象给析构。

补充

经测试,以下代码也是可以的

// undefied behavior for 0 > _len 
template<class _T>
class Vec{
public:
    Vec() : _len(0), _dat(NULL) {}
    Vec(const int32_t len) {
        _len = len;
        _dat = new _T[len];
    }
    Vec(const int32_t len, const _T &val) {
        _len = len;
        _dat = new _T[len];
        for (int32_t i = 0; i < _len; i++){
            _dat[i] = val;
        }
    }
    ~Vec(){
        if (_dat){
            delete[] _dat;  _dat = NULL;
        }
        _len = 0;
    }

public:
    template<class T2>
    Vec<_T>& operator=(const Vec<T2> &B){
        if (_dat){
            delete[] _dat;
        }
        _len = B.get_len();
        if (0!=_len){
            _dat = new _T[B.get_len()];
        }
        for (int i = 0; i < _len; i++){
            _dat[i] = B.get_dat()[i];
        }
        return *this;
    }

public: // utilities
    template<class T>
    friend std::ostream& operator<<(std::ostream &output, Vec<T> &am);

    int32_t get_len() const{
        return _len;
    }
    _T* get_dat() const {
        return _dat;
    }
private:
    int32_t _len;
    _T* _dat;
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值