C++2.0

C++模板编程/泛型编程

2019-07-29  本文已影响7人  new_liziang

模板分类

模板分为函数模板与类模板两类。

函数模板

template <模板形参表> 函数返回类型 函数(形参表);
template <模板形参表>
函数返回类型 函数(形参表){
      函数体;
};

例如

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

函数模板实参类型不一致问题

template <typename T> 
inline const T& Max(const T& a, const T& b){
        return a>b?a:b;
}

Max(2,2.4)

参数推导会出现模板实参类型int与double不一致的错误。

解决方法:

1.每个模板参数独立类型

template <typename T , typename U> inline const T& Max(const T& a, const U& b){
        return a>b?a:b;
}

注意:这种解决方法还有一个问题,就是返回值只能强制设置为T或者U,不能自动推导。

C++11的后置推导可以解决这个问题。

template <typename T, typename U> 
inline auto Max(const T& a, const U& b)->decltype(a>b?a:b)
{
        return a>b?a:b;
}

2.显示指定模板实参类型

Max<int>(2,2.4)

或者

Max<double>(2,2.4)

3.实参强制类型转换

Max(2,static_cast<int>(2.4))

或者

Max(static_cast<double>(2),2.4)

概念

类模板参数允许自动类型转换(隐式转换);函数模板参数不允许自动类型转换(隐式转换)


类模板

template <模板形参表> class 类名;
template <模板形参表>
class 类名 {
}
类名<模板实参表> 对象;

类模板
类模板:不完整的类,一个或者多个成员类型未确定。
函数模板:不完整的函数,一个或者多个参数类型未确定。
成员函数:只有调用时才会被实例化。
静态成员:每次类模板实例化,都会被实例化。

类实例化成对象,类模板实例化成类。

类模板特化,每个成员函数必须重新定义。

类模板特化,相当于函数模板的重载

实例:三元组模版Triple

上一篇下一篇

猜你喜欢

热点阅读