函数模板和类模板

🗨️字数统计=846字 ⏳阅读时长≈4分钟

一、函数模板


二、类模板

直接上示例


类模板示例

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
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;
}

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

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
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 * (); 重载隐式转换的作用

分享到