函数模板和类模板

C++
2024-12-25 09:26

一、函数模板


二、类模板

直接上示例

类模板示例

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 * (); 重载隐式转换的作用


相关文章
热点文章
精彩视频
Tags

站点地图 在线访客: 今日访问量: 昨日访问量: 总访问量: