C++函数模板和类模板——DAY2

1.函数模板遇上普通函数:
调用函数模板(本质:类型参数化),将严格的按照类型进行匹配,不会进行自动类型转换;
普通函数的调用:可以进行隐式的类型转换
具体规则如下:
1.函数模板可以像普通函数一样被重载;
2.c++编译器优先考虑普通函数;
3.如果函数模板可以产生一个更好的匹配,那么选择函数模板;
4.可以通过空模板实参列表的语法限定编译器只通过模板匹配。
如下代码为具体说明:


#include <iostream>
using namespace std;


int Max(int a, int b)
{
	cout<<"int Max(int a, int b)"<<endl;
	return a > b ? a : b;
}

template<typename T>
T Max(T a, T b)
{
	cout<<"T Max(T a, T b)"<<endl;
	return a > b ? a : b;
}

template<typename T>
T Max(T a, T b, T c)
{
	cout<<"T Max(T a, T b, T c)"<<endl;
	return Max(Max(a, b), c);
}


int main()
{
	int a = 1;
	int b = 2;

	cout<<Max(a, b)<<endl; //当函数模板和普通函数都符合调用时,优先选择普通函数
	cout<<Max<>(a, b)<<endl; //若显示使用函数模板,则使用<> 类型列表

	cout<<Max(3.0, 4.0)<<endl; //如果 函数模板产生更好的匹配 使用函数模板,小数转换为浮点数会失真 

	cout<<Max(5.0, 6.0, 7.0)<<endl; //重载

	cout<<Max('a', 100)<<endl;  //调用普通函数 可以隐式类型转换 
	system("pause");
	return 0;
}

猜你喜欢

转载自blog.csdn.net/qq_41536360/article/details/88981952
今日推荐