静态数据成员对象之间共享的,当静态数据成员遇上类模板式也是如此吗?
现有demo类模板,类中包含static数据成员。
template <typename T>
class A
{
public:
A(T t = 0);
T& getT();
A operator +(const A& other);
void print();
public:
static int count;
private:
T t;
};
为了便于观察,将主函数接口与类模板成员函数实现写在类声明同一文件下:
demo.cpp
#include <iostream>
using namespace std;
template <typename T>
class A
{
public:
A(T t = 0);
T& getT();
A operator +(const A& other);
void print();
public:
static int count;
private:
T t;
};
template <typename T> int A<T>::count = 666;
template <typename T>
A<T>::A(T t)
{
this->t = t;
}
template <typename T>
T& A<T>::getT()
{
return t;
}
template <typename T>
A<T> A<T>::operator+(const A<T>& other) {
A tmp; //类的内部类型可以显示声明也可以不显示
tmp.t = this->t + other.t;
return tmp;
}
template <typename T>
void A<T>::print() {
cout << this->t << endl;
}
int main(void) {
A<int> a(666), b(888);
A<int> tmp = a + b;
A<float> c(777), d(999);
a.count = 888;
cout << "b.count:" << b.count << endl;
cout << "c.count:" << c.count << endl;
cout << "d.count:" << d.count << endl;
c.count = 1000;
cout << "修改后, d.count:" << d.count << endl;
//tmp.print();
system("pause");
return 0;
}
运行结果:
?
当将 虚拟类型T被int实例化以后,这个模板类就会生成一个类名为A,数据类型为int的类,将T实例化为float后,也会生成一个类名为A,数据类型为float的类,这是两个不同的类,当然,编译器会做一些处理,不让两个类同名,只不过我们看到的是同名。
总结:
- 从类模板实例化的每个模板类有自己的类模板数据成员,该模板类的所有对象共享一个static数据成员
- ?和非模板类的static数据成员一样,模板类的static数据成员也应该在文件范围定义和初始化
- static 数据成员也可以使用虚拟类型参数T
?static 数据成员也可以使用虚拟类型参数T,例如:
class A
{
public:
A(T t = 0);
public:
static T count;
private:
T t;
};
template <typename T> T A<T>::count = 666;
跟之前操作一样~
?
?
?
?
|