1 函数模板的使用与注意事项
分类:
- 函数模板
- 类模板
利用模板实现通用的函数
template<typename T>
//T是通用类型,告诉编译器后面紧跟者的函数或者类型中出现了T,不要报错
//如:
template<typename T>
void mySwap(T&a,T&b)
{
T temp = a;
a = b;
b = temp;
}
注意事项:
//1、自动类型推导,必须让编译器推导出一致的T,才能使用模板
int a;
int b;
char x = 'x';
//mySwap(a,x) 错误 不能推导出一致的类型
//正确写法
mySwap(a,b);
//2、显示指定类型
mySwap<int>(a,b);//可以进行隐式类型转换
//3、模板必须要指定出T的类型,才可以使用
例如:
template<typename T>
void mySwap2()
{
}
mySwap2<double>();
案例:
//交换函数模板
template<class T>
void mySwap(T & a, T & b)
{
T temp = a;
a = b;
b = temp;
}
//利用选择排序实现对 int 和 char 数组排序,从小到大
template<typename T>
void mySort(T arr[], int len)
{
for(int i = 0; i < len; i++)
{
int min = i;
for(int j = i + 1; j < len; j++)
{
if(arr[min] > arr[j])
{
min = j;//记录最小值的下标
}
}
//判断最小值下标和开始认定的i是否相等,如果不相等,交换i和min的下标数据
if(min != i)
{
mySwap(arr[i],arr[min]);
}
}
}
//打印函数模板
template<class T>
void printArry(T Arr[], int len)
{
for(int i = 0; i < len; i++)
{
cout << arr[i] << endl;
}
}
int main()
{
int arr[] = {15,34,64,9};
int len = sizeof(arr)/sizeof(arr[0]);
mySort(arr,len);
printArray(arr,len);
char charArr[] = "helloworld";
len = sizeof(charArr)/sizeof(char);
mySort(charArr,len);
printArray(charArr,len);
}
2普通函数和函数模板的区别以及调用规则
//1、如果普通函数和函数模板同时调用,优先使用的是普通函数
//2、如果想强制调用函数模板中的内容,可以是使用空参数列表
myPrint<>(a,b);
//3、函数模板也可以发生重载
myPrint(a,b,10);
//4、如果函数模板可以产生更好的匹配,那么优先使用的是函数模板
3 模板实现机制
- 编译器并不是把函数模板处理成能够处理任何类型的函数
- 函数模板通过具体类型产生不同的函数
- 编译器会对函数模板进行两次编译,在声明的地方对模板代码本身进行编译,在调用的地方对参数替换后的代码进行编译。
4 模板的局限性
如果代码的实现时定义了赋值操作 a=b,但是T为数组,这种假设就不成立了。可以利用具体化的方法来解决。
class Person
{
Person(string name, int age)
{
this->m_Name = name;
this->m_Age = age;
}
string m_Name;
int m_Age;
};
//利用具体化的Person函数,告诉编译器 走Person比较代码
template<> bool myCompare<Person>(Person &a, Person &b)
{
cout << "调用的时具体化的代码"<< endl;
if(a.m_Name == b.m_Name && a.m_Age == b.m_Age)
{
return true;
}
return false;
}
//通过模板进行两个数据的比较
template<class T>
bool myCompare(T &a, T &b)
{
if(a == b)
{
return true;
}
return false;
}
void test01()
{
Person p1("Tom",19);
Person p2("Jerry",20);
bool ret = myCompare(p1,p2);
if(ret)
{
cout << "p1与p2相等"<<endl;
}
else
{
cout << "不相等"<<endl;
}
}
int main()
{
test01();
return 0;
}