demo 1

#include <iostream>
using namespace std;

//让 类型參数化 ===, 方便程序猿进行编码
// 泛型编程
//template 告诉C++编译器 我要開始泛型编程了 .看到T, 不要随便报错
template <typename T>
void myswap(T &a, T &b)
{
T c = 0;
c = a;
a = b;
b = c;
cout << "hello ....我是模板函数 欢迎 calll 我" << endl;
}

void myswap(int a, char c)
{
cout << "a:" << a << "c:" << c << endl;
cout << "我是普通函数 欢迎来訪" << endl;
}


void main()
{
int a = 10;
char c = 'z';

myswap(a, c); // 普通函数的调用: 能够进行隐式的类型转换
myswap(c, a); // 调用函数模版

myswap(a, a); // 函数模板函数的调用(本质:类型參数化): 将严格的依照类型进行匹配,不会进行自己主动类型转换


cout<<"hello..."<<endl;
system("pause");
return ;
}

通过demo 1能够得到:

函数模板和普通函数差别结论:

1、函数模板不同意自己主动类型转化;

2、普通函数可以进行自己主动类型转换。


demo 2

/*
函数模板不同意自己主动类型转化
普通函数能够进行自己主动类型转换
*/


#include "iostream"
using namespace std;


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