/*
一、关于类模板做函数参数的形式,一般包括三种类型:
a.直接指定传入类型:在写函数参数表时直接用具体类型替代类模板
b.参数模板化:在写函数参数表时,继续使用类模板(要重新声明),与以前介绍的函数模板相同;这种情况下,只有在程序运行时具体
包含已赋值的对象作为参数传入函数时,类模板类型才能确定。
c.整个类模板化:可以理解成把类模板参数表再模板化一次。具体情况和 b 差不多。
二、下面用一个小程序对上述情况举例说明:(具体代码已在VS2022通过)
总结起来看,无论怎样使用模板,程序都必须能够在某一地方找到模板代表的具体类型,否则程序是无法运行的。
*/
#include<iostream>
using namespace std;
#include <string>
// 以下声明类模板,再用模板声明一个类(后边的例子均使用此类的对象做参数)
template <class T1,class T2>
class myClass
{
public:
T1 mV1; //声明两个成员变量
T2 mV2;
myClass(T1 v1,T2 v2) //有参构造函数赋值使用
{
this->mV1 = v1;
this->mV2 = v2;
}
void mShow() //成员函数用于显示成员变量
{
cout<<"mV1="<<this->mV1<<" mV2="<<this->mV2<<endl;
}
};
//1. mPrint01函数:直接指定传入类型
void mPrint01(myClass<string,int> &myClass1) //string、int直接替代T1、T2
{
myClass1.mShow();
}
void test01()
{
myClass<string,int> mc1("ABC", 100);
mPrint01(mc1); //调用mPrint01
cout << "---------------- 方法一 --------------------" << endl;
}
//2. 参数模板化
template <class TT1,class TT2> //再次声明类模板
void mPrint02(myClass<TT1,TT2> &myClass2)//这里参数模板化实质是函数模板
{
myClass2.mShow();
cout<<typeid(TT1).name()<<"----" << typeid(TT2).name() << endl;
//利用typeid函数显示模板类型
//补充:对非引用类型typeid是在编译时期识别的,只有引用类型才会在运行时识别
};
void test02()
{
myClass <string,int> mc2("BCD",200); //实例化并调用构造函数赋值
mPrint02(mc2);
cout << "---------------- 方法二 --------------------" << endl;
}
//3. 整个类模板化
template<class TTT> //声明类模板
void mPrint3(TTT &myClass3) //将用模板T1、T2声明的myClass类型再用模板TTT代替
{
myClass3.mShow();
};
void test03()
{
myClass <string,int> mc3("CDE",300);
mPrint3(mc3);
cout << "---------------- 方法三 --------------------" << endl;
};
int main()
{ test01();
test02();
test03();
system("pause");
return 0;
}
DeepStream做对象模糊的几种方法
2024-02-20 20:16:03 38 阅读