C++模板特化(template)

发布时间:2020-07-25 18:47:10 作者:梦T醒
来源:网络 阅读:436

C++模板特化(template)
模板为什么存在?
相信大家都写过Add函数

int Add(int left,int right)
{
    return left+right;
}

double Add(double left,int right)
{
    return left+right;
}

这种写法会使代码冗余,而且不美观,所以就需要一个通用的Add函数,模板就出现了

template<class T>       //或template<typename T>
T Add(T left,T right)
{
    cout << typeid(T).name() << endl;//查看调用模板的类型
    return left+right;
}

模板特化存在的必要性
上面的模板只能解决一些普通的类型,但对于特殊的类型就会出错
比如:

template<class T>
T& Max(T& left, T& right)
{
    return left > right? left : right;
}
int main()
{
    char* p1 = "world";
    char* p2 = "hello";
    cout << Max(p1, p2) << endl;
}

模板特化中的函数特化
对于上面char*类型的解决方法:

 template<>
 char*& Max<char*>(char*& left, char*& right)
 {
    if (strcmp(left, right) > 0)
        return left;

    return right;
 }

C++模板特化(template)【注意】

使用模板特化时,必须要先有基础的模板函数(就是上面第一个模板函数)

使用特换模板函数时格式有要求:

1.template 后直接跟<> 里面不用写类型
2.函数名<特化类型>(特化类型 参数1, 特化类型 参数2 , …) 在函数名后跟<>其中写要特化的类型

特化的函数的函数名,参数列表要和原基础的模板函数想相同,避免不必要的错误
也可以写为

char* Max(char* left, char* right)
{
    if (strcmp(left, right) > 0)
        return left;

    return right;
}

编译器当检测到普通函数和模板都可以使用时,优先使用普通函数
所以,函数模板一般不需要特化,直接将不能处理类型的具体函数给出
模板特化中的类特化
1.全特化

template<class T1,class T2>
T1& Max(T1& left, T2& right)  //返回类型自定T1或T2
{
    return left > right? left : right;
}

2.偏特化(部分特化)

//都可以
template<T,int>
template<T,int>
template<double,T>
template<T,double>

编译器在调用模板时,偏特化模板优于全特化模板
C++模板特化(template)总结:在调用模板时,优先级
普通函数<偏特化<全特化

推荐阅读:
  1. golang 模板(template)的常用基本语法
  2. C++模板的特化与偏特化

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

c++模板 函数模板特化 类模板特化

上一篇:利用Galera Cluster解决主主复制单点问题

下一篇:使用IP代理池和用户代理池爬取糗事百科文章

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》