当前位置: 代码迷 >> C++ >> 关于模板函数的匹配有关问题
  详细解决方案

关于模板函数的匹配有关问题

热度:10450   发布时间:2013-02-26 00:00:00.0
关于模板函数的匹配问题

template<typename T> 
void trace(const T obj, bool newline = true);// #1

template<>
void trace<const stringstream*>(const stringstream* obj, bool newline);// #2

template<>
void trace<string*>(string* obj, bool newline);// #3

template<>
void trace<const char*>(const char* obj, bool newline);// #4


下面这段调用

stringstream ss0;
ss0 << 100;
trace(&ss0);//我发现在这里匹配的是#2

const stringstream ss1;
ss1 << 100;
trace(&ss1);//我发现在这里匹配的是#1


这意味着,假如这个模板函数要提供给别人使用,真对const stringstream* 和 stringstream* 我需要具体化两个模板函数。

template<>
void trace<const stringstream*>(const stringstream* obj, bool newline);//给const stringstream *使用
template<>
void trace<stringstream*>(stringstream* obj, bool newline);//给stringstream *使用

真心觉得好麻烦啊。有什么方法可以一个模板具体化搞定吗?
谢谢各位高人了!
模板 具体化 c c++

------解决方案--------------------------------------------------------
特化没办法,不过可以用重载。

template <typename T>
typename
std::enable_if<std::is_same<std::stringstream,
                            typename std::remove_const<T>::type
                           >::value
              >::type
trace (T*const, bool = true); // #2

话说回来,通常情况下,const 和 non-const 类型的实现方法也不一样。你的例子如果是这样的话,接口统一就没法实现,因为内部处理的逻辑不一样的话,还是要想办法分开的。
------解决方案--------------------------------------------------------
#include <iostream>
#include <sstream>
#include <string>

template<typename T>
void trace(const T obj, bool newline = true)// #1
 {
    std::cout<< "#1";
 }
template<>
void trace<const std::stringstream*>(const std::stringstream* obj, bool newline)
{
    std::cout<< "#2";
}

template<>
void trace<std::string*>(std::string* obj, bool newline)
{
    std::cout<< "#3";
}

template<>
void trace<const char*>(const char* obj, bool newline)
{
    std::cout<< "#4";
}

int main()
{
    std::stringstream ss0;
    ss0 << 100;
    trace(&ss0);

    const std::stringstream ss1;
    //ss1 << 100;
    trace(&ss1);
    return 0;
}

gcc 4.6.2运行结果:
  相关解决方案