模板笔记

1.当使用函数模板并且引起模板实例化的时候,编译器需要查看模板的定义

2.template<typename T1, typename T2>//实参演绎

inline T1 max(T1 const& a, T2 const& b)//注意函数模板的返回类型只能是T1,不能是T1&,因为有可能返回的是b,局部对象类型要转换为T1

{

  return a > b ? a : b;  

}

3.template<typename T1, typename T2, typename T>

inline T max(T1 const& a, T2 const& b)//由于T类型没有出现在函数调用参数里面不能实参演绎,必须显示指定3个类型

{

  return a > b ? a : b;  

}

max<int, double, double>(4, 4.2)

4.也可以指定部分模板参数类型,但是最后一个不能被隐式演绎的模板实参之前的所有参数,包括它本身。

max<int>(4, 4.2)//这样调用也可以

 

#include <iostream>
#include <string>

using namespace std;
inline int max(int const& a, int const& b)
{
cout << "<int>" << endl;
return a > b ? a: b;
}
template<typename T>
inline T const& max(T const& a, T const& b)
{
cout << "<T a b>" << endl;
return a > b ? a : b;
}

template<typename T>
inline T const /*注意这里如果返回引用会报赶回临时对象的引用,引发错误*/max(T const& a, T const& b ,T const& c)
{
cout << "<T a b c>" << endl;
return ::max(::max(a, b), c);
}
int main()
{
cout << "max(1, 2) "<< ::max(1, 2) << endl;
cout << "max(1.0, 2.0) "<< ::max(1.0, 2.0) << endl;
cout << "max<>(1, 2) " << ::max<>(1, 2) << endl;
cout << "max('a', 'b') " << ::max('a', 'b') << endl;
cout << "max('a', 2.0) " << ::max('a', 2.0) << endl;//因为模板不允许自动类型转换,只能调用非模板函数
cout << "max(1, 2, 3.0) " << ::max(1, 2, 3) << endl;
}

posted @   MoonXu  阅读(175)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
点击右上角即可分享
微信分享提示