【C++复习总结回顾】—— 【八】函数模板和类模板


一、函数模板

二、类模板

直接上示例

类模板示例

template<class T>
class Store{
    private:
        T item; //item用于存放任意类型的数据
        bool haveValue; //标记item是否已经被存入内容
    public:
        T &getElem(); //提取数据
        void putElem(const T& x); //存入数据
        Store();
};

template<class T>
Store<T>::Store():haveValue(false){ }

template<class T>
T& Store<T>::getElem(){
    if(!haveValue){
        cout<<"no data!"<<endl;
        exit(1); //使程序完全退出,返回操作系统
    }
    return item;
}

template<class T>
void Store<T>::putElem(const T& x){
    item = x;
    haveValue = true;
}

struct student{
    int id;
    float gpa;
};
int main(){
    Store<int>s1;
    s1.putElem(4);
    cout<<s1.getElem()<<endl;
    student s= {1001,98.2};
    Store<student> s2;
    s2.putElem(s);
    cout<<s2.getElem().id<<" "<<s2.getElem().gpa<<endl; 
}

三、自定义动态数组类模板

template <class T>
class Array
{
private:
    T *list;  //T类型指针,存放动态分配的数组首地址
    int size; //数组大小
public:
    Array(int sz = 50);
    Array(const Array<T> &a); //复制构造
    ~Array();
    Array<T> &operator=(const Array<T> &rhs);
    T &operator[](int i);             //重载下标运算符 可被改变 a[3] = 5
    const T &operator[](int i) const; //重载下标运算符 常函数
    operator T *();                   //重载隐式转换,将对象重载为T*类型
    operator const T *() const;
    int getSize() const; //获取数组大小
    void reSize(int sz); //修改数组大小
};
//构造函数
template <class T>
Array<T>::Array(int sz)
{
    assert(sz >= 0);
    size = sz;
    list = new T[size]; //动态分配数组空间
}
//拷贝构造(深层复制)
template <class T>
Array<T>::Array(const Array<T> &a)
{
    size = a.size;
    list = new T[size];
    for (int i = 0; i < size; i++)
        list[i] = a.list[i];
}
//析构函数
template <class T>
Array<T>::~Array()
{
    delete[] list;
}
//重载=
template <class T>
Array<T> &Array<T>::operator=(const Array<T> &rhs)
{
    if (this != &rhs)
    { //避免自身复制
        if (size != rhs.size)
        { //如果两个数组的大小不同,则需要重新分配内存空间
            delete[] list;
            size = rhs.size;
            list = new T[size];
        }
        for (int i = 0; i < size; i++)
            list[i] = rhs.list[i];
    }
    return *this; //返回当前对象的引用
}
//重载下标运算符[ ],实现与普通数组一样通过下标访问元素,具有越界检查功能 
template <class T>
T &Array<T>::operator[](int i)
{
    assert(i >= 0 && i < size);
    return list[i];
    //return *(list+i);
}
//重载[ ]常函数
template <class T>
const T &Array<T>::operator[](int i) const
{
    assert(i >= 0 && i < size);
    return list[i];
    //return *(list+i);
}
//重载到T*类型的转换
template <class T>
Array<T>::operator T *()
{
    return list; //返回当前对象私有数组的首地址
}
//重载到T*类型的转换 常函数
template <class T>
Array<T>::operator const T *() const
{
    return list;
}
template <class T>
int Array<T>::getSize() const
{
    return size;
}
template <class T>
void Array<T>::reSize(int sz)
{
    assert(sz >= 0);
    if (sz == size)
        return;
    T *newlist = new T[sz];          //申请新的数组内存
    int n = (sz < size ? sz : size); //将较小值赋给n
    for (int i = 0; i < n; i++)
        newlist[i] = list[i];
    delete[] list;  //删除原数组
    list = newlist; //使list指向新数组
    size = sz;      //更新size
}

其中 operator T * (); 重载隐式转换的作用

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

飞天小牛肉

您的鼓励是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值